react-native-tvos 0.73.7-1 → 0.74.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.d.ts +6 -0
- package/Libraries/ActionSheetIOS/ActionSheetIOS.js +6 -0
- package/Libraries/ActionSheetIOS/NativeActionSheetManager.js +4 -45
- package/Libraries/Alert/NativeAlertManager.js +4 -26
- package/Libraries/Animated/Animated.js +2 -2
- package/Libraries/Animated/AnimatedPlatformConfig.js +1 -1
- package/Libraries/Animated/NativeAnimatedHelper.js +14 -11
- package/Libraries/Animated/NativeAnimatedModule.js +4 -68
- package/Libraries/Animated/NativeAnimatedTurboModule.js +4 -69
- package/Libraries/Animated/animations/Animation.js +6 -22
- package/Libraries/Animated/components/AnimatedFlatList.js +1 -16
- package/Libraries/Animated/components/AnimatedScrollView.js +36 -31
- package/Libraries/Animated/components/AnimatedSectionList.js +1 -20
- package/Libraries/Animated/createAnimatedComponent.js +45 -40
- package/Libraries/Animated/nodes/AnimatedStyle.js +1 -1
- package/Libraries/Animated/shouldUseTurboAnimatedModule.js +1 -1
- package/Libraries/Animated/useAnimatedProps.js +21 -1
- package/Libraries/AppDelegate/RCTAppDelegate.h +35 -16
- package/Libraries/AppDelegate/RCTAppDelegate.mm +122 -177
- package/Libraries/AppDelegate/RCTAppSetupUtils.h +8 -17
- package/Libraries/AppDelegate/RCTAppSetupUtils.mm +55 -41
- package/Libraries/AppDelegate/RCTRootViewFactory.h +133 -0
- package/Libraries/AppDelegate/RCTRootViewFactory.mm +270 -0
- package/Libraries/AppDelegate/React-RCTAppDelegate.podspec +15 -38
- package/Libraries/AppState/NativeAppState.js +4 -24
- package/Libraries/BatchedBridge/NativeModules.js +1 -1
- package/Libraries/Blob/Blob.js +1 -4
- package/Libraries/Blob/BlobManager.js +6 -8
- package/Libraries/Blob/File.js +1 -1
- package/Libraries/Blob/NativeBlobModule.js +4 -50
- package/Libraries/Blob/NativeFileReaderModule.js +4 -13
- package/Libraries/Blob/RCTBlobCollector.mm +1 -1
- package/Libraries/Blob/RCTBlobManager.h +4 -0
- package/Libraries/Blob/RCTBlobManager.mm +30 -4
- package/Libraries/Blob/RCTFileReaderModule.mm +2 -2
- package/Libraries/Blob/React-RCTBlob.podspec +9 -2
- package/Libraries/BugReporting/NativeBugReporting.js +4 -12
- package/Libraries/Components/AccessibilityInfo/NativeAccessibilityInfo.js +3 -23
- package/Libraries/Components/AccessibilityInfo/NativeAccessibilityManager.js +4 -57
- package/Libraries/Components/AccessibilityInfo/legacySendAccessibilityEvent.android.js +3 -2
- package/Libraries/Components/ActivityIndicator/ActivityIndicator.js +9 -40
- package/Libraries/Components/ActivityIndicator/ActivityIndicatorViewNativeComponent.js +3 -43
- package/Libraries/Components/Button.js +103 -107
- package/Libraries/Components/Clipboard/NativeClipboard.js +2 -24
- package/Libraries/Components/DrawerAndroid/AndroidDrawerLayoutNativeComponent.js +3 -114
- package/Libraries/Components/DrawerAndroid/DrawerLayoutAndroid.android.js +1 -5
- package/Libraries/Components/Keyboard/NativeKeyboardObserver.js +3 -10
- package/Libraries/Components/Pressable/Pressable.js +1 -1
- package/Libraries/Components/Pressable/useAndroidRippleForView.js +5 -4
- package/Libraries/Components/ProgressBarAndroid/ProgressBarAndroidNativeComponent.js +4 -24
- package/Libraries/Components/RefreshControl/AndroidSwipeRefreshLayoutNativeComponent.js +3 -64
- package/Libraries/Components/RefreshControl/PullToRefreshViewNativeComponent.js +3 -61
- package/Libraries/Components/RefreshControl/RefreshControl.js +1 -1
- package/Libraries/Components/SafeAreaView/RCTSafeAreaViewNativeComponent.js +3 -15
- package/Libraries/Components/ScrollView/AndroidHorizontalScrollContentViewNativeComponent.js +3 -16
- package/Libraries/Components/ScrollView/ScrollContentViewNativeComponent.js +1 -1
- package/Libraries/Components/ScrollView/ScrollView.d.ts +5 -6
- package/Libraries/Components/ScrollView/ScrollView.js +12 -38
- package/Libraries/Components/ScrollView/ScrollViewStickyHeader.js +1 -2
- package/Libraries/Components/Sound/NativeSoundManager.js +3 -12
- package/Libraries/Components/StatusBar/NativeStatusBarManagerAndroid.js +3 -58
- package/Libraries/Components/StatusBar/NativeStatusBarManagerIOS.js +3 -85
- package/Libraries/Components/Switch/AndroidSwitchNativeComponent.js +4 -53
- package/Libraries/Components/Switch/Switch.js +0 -2
- package/Libraries/Components/Switch/SwitchNativeComponent.js +4 -52
- package/Libraries/Components/TV/TVEventHandler.js +1 -1
- package/Libraries/Components/TextInput/AndroidTextInputNativeComponent.js +8 -0
- package/Libraries/Components/TextInput/InputAccessoryView.js +18 -20
- package/Libraries/Components/TextInput/RCTInputAccessoryViewNativeComponent.js +4 -17
- package/Libraries/Components/TextInput/RCTTextInputViewConfig.js +3 -6
- package/Libraries/Components/TextInput/TextInput.d.ts +16 -0
- package/Libraries/Components/TextInput/TextInput.flow.js +16 -0
- package/Libraries/Components/TextInput/TextInput.js +65 -32
- package/Libraries/Components/ToastAndroid/NativeToastAndroid.js +3 -28
- package/Libraries/Components/Touchable/PooledClass.js +1 -1
- package/Libraries/Components/Touchable/Touchable.js +2 -3
- package/Libraries/Components/Touchable/TouchableHighlight.js +4 -4
- package/Libraries/Components/Touchable/TouchableNativeFeedback.js +2 -1
- package/Libraries/Components/Touchable/TouchableOpacity.js +5 -2
- package/Libraries/Components/UnimplementedViews/UnimplementedNativeViewNativeComponent.js +3 -16
- package/Libraries/Components/View/ReactNativeStyleAttributes.js +2 -1
- package/Libraries/Components/View/View.js +0 -11
- package/Libraries/Components/View/ViewAccessibility.d.ts +33 -17
- package/Libraries/Components/View/ViewPropTypes.d.ts +28 -17
- package/Libraries/Components/View/ViewPropTypes.js +36 -36
- package/Libraries/Core/InitializeCore.js +1 -1
- package/Libraries/Core/NativeExceptionsManager.js +3 -93
- package/Libraries/Core/ReactNativeVersion.js +12 -6
- package/Libraries/Core/ReactNativeVersionCheck.js +6 -6
- package/Libraries/Core/SegmentFetcher/NativeSegmentFetcher.js +3 -18
- package/Libraries/Core/Timers/NativeTiming.js +3 -16
- package/Libraries/Core/registerCallableModule.d.ts +16 -0
- package/Libraries/Core/registerCallableModule.js +42 -0
- package/Libraries/Core/setUpPerformance.js +2 -2
- package/Libraries/Core/setUpPerformanceObserver.js +3 -1
- package/Libraries/Debugging/DebuggingOverlay.js +111 -0
- package/Libraries/Debugging/DebuggingOverlayNativeComponent.js +13 -0
- package/Libraries/Debugging/DebuggingOverlayRegistry.js +513 -0
- package/Libraries/Debugging/useSubscribeToDebuggingOverlayRegistry.js +32 -0
- package/Libraries/DevToolsSettings/NativeDevToolsSettingsManager.js +3 -14
- package/Libraries/HeapCapture/NativeJSCHeapCapture.js +3 -9
- package/Libraries/Image/AssetSourceResolver.js +5 -5
- package/Libraries/Image/AssetUtils.js +4 -5
- package/Libraries/Image/Image.android.js +146 -174
- package/Libraries/Image/Image.d.ts +1 -1
- package/Libraries/Image/Image.ios.js +53 -79
- package/Libraries/Image/Image.js.flow +3 -30
- package/Libraries/Image/ImageBackground.js +2 -2
- package/Libraries/Image/ImageInjection.js +76 -18
- package/Libraries/Image/ImageTypes.flow.js +71 -0
- package/Libraries/Image/ImageUtils.js +1 -1
- package/Libraries/Image/ImageViewNativeComponent.js +18 -0
- package/Libraries/Image/NativeImageEditor.js +3 -42
- package/Libraries/Image/NativeImageLoaderAndroid.js +4 -28
- package/Libraries/Image/NativeImageLoaderIOS.js +4 -28
- package/Libraries/Image/NativeImageStoreAndroid.js +3 -16
- package/Libraries/Image/NativeImageStoreIOS.js +3 -23
- package/Libraries/Image/RCTImageLoader.mm +4 -11
- package/Libraries/Image/RCTImageStoreManager.h +2 -0
- package/Libraries/Image/RCTImageStoreManager.mm +37 -10
- package/Libraries/Image/RCTUIImageViewAnimated.mm +0 -5
- package/Libraries/Image/React-RCTImage.podspec +3 -2
- package/Libraries/Image/resolveAssetSource.js +59 -26
- package/Libraries/Inspector/ElementProperties.js +26 -52
- package/Libraries/Inspector/Inspector.js +122 -186
- package/Libraries/Inspector/InspectorOverlay.js +21 -33
- package/Libraries/Inspector/InspectorPanel.js +3 -17
- package/Libraries/Inspector/ReactDevToolsOverlay.js +171 -0
- package/Libraries/Inspector/getInspectorDataForViewAtPoint.js +20 -8
- package/Libraries/Interaction/FrameRateLogger.js +8 -18
- package/Libraries/Interaction/NativeFrameRateLogger.js +4 -16
- package/Libraries/IntersectionObserver/IntersectionObserver.js +1 -1
- package/Libraries/IntersectionObserver/IntersectionObserverEntry.js +20 -19
- package/Libraries/IntersectionObserver/IntersectionObserverManager.js +84 -6
- package/Libraries/IntersectionObserver/NativeIntersectionObserver.h +6 -24
- package/Libraries/IntersectionObserver/NativeIntersectionObserver.js +3 -31
- package/Libraries/IntersectionObserver/__mocks__/NativeIntersectionObserver.js +12 -2
- package/Libraries/LayoutAnimation/LayoutAnimation.js +1 -2
- package/Libraries/Linking/NativeIntentAndroid.js +3 -20
- package/Libraries/Linking/NativeLinkingManager.js +3 -17
- package/Libraries/LinkingIOS/React-RCTLinking.podspec +3 -2
- package/Libraries/Lists/FillRateHelper.js +1 -1
- package/Libraries/Lists/FlatList.d.ts +2 -2
- package/Libraries/Lists/FlatList.js +6 -2
- package/Libraries/Lists/SectionList.d.ts +6 -1
- package/Libraries/Lists/ViewabilityHelper.js +1 -1
- package/Libraries/Lists/VirtualizeUtils.js +1 -1
- package/Libraries/Lists/VirtualizedList.js +1 -1
- package/Libraries/Lists/VirtualizedListContext.js +1 -1
- package/Libraries/Lists/VirtualizedSectionList.js +1 -1
- package/Libraries/LogBox/LogBoxInspectorContainer.js +1 -1
- package/Libraries/Modal/Modal.js +43 -11
- package/Libraries/Modal/NativeModalManager.js +3 -11
- package/Libraries/Modal/RCTModalHostViewNativeComponent.js +3 -129
- package/Libraries/MutationObserver/MutationObserver.js +1 -1
- package/Libraries/MutationObserver/MutationObserverManager.js +2 -2
- package/Libraries/MutationObserver/MutationRecord.js +12 -10
- package/Libraries/MutationObserver/NativeMutationObserver.cpp +2 -3
- package/Libraries/MutationObserver/NativeMutationObserver.h +8 -20
- package/Libraries/MutationObserver/NativeMutationObserver.js +3 -48
- package/Libraries/MutationObserver/__mocks__/NativeMutationObserver.js +1 -1
- package/Libraries/NativeAnimation/RCTNativeAnimatedTurboModule.mm +116 -85
- package/Libraries/NativeAnimation/React-RCTAnimation.podspec +3 -2
- package/Libraries/NativeComponent/BaseViewConfig.android.js +4 -0
- package/Libraries/NativeComponent/BaseViewConfig.ios.js +3 -0
- package/Libraries/NativeComponent/NativeComponentRegistry.js +1 -1
- package/Libraries/NativeComponent/TVViewConfig.js +17 -0
- package/Libraries/NativeModules/specs/NativeAnimationsDebugModule.js +3 -10
- package/Libraries/NativeModules/specs/NativeDevMenu.js +3 -13
- package/Libraries/NativeModules/specs/NativeDevSettings.js +3 -23
- package/Libraries/NativeModules/specs/NativeDeviceEventManager.js +3 -9
- package/Libraries/NativeModules/specs/NativeDialogManagerAndroid.js +3 -38
- package/Libraries/NativeModules/specs/NativeLogBox.js +3 -10
- package/Libraries/NativeModules/specs/NativeRedBox.js +4 -11
- package/Libraries/NativeModules/specs/NativeSourceCode.js +2 -25
- package/Libraries/Network/FormData.js +3 -1
- package/Libraries/Network/NativeNetworkingAndroid.js +4 -28
- package/Libraries/Network/NativeNetworkingIOS.js +4 -28
- package/Libraries/Network/RCTHTTPRequestHandler.mm +2 -2
- package/Libraries/Network/RCTNetworkTask.mm +15 -1
- package/Libraries/Network/RCTNetworking.h +6 -0
- package/Libraries/Network/RCTNetworking.mm +84 -44
- package/Libraries/Network/React-RCTNetwork.podspec +3 -2
- package/Libraries/Performance/NativeJSCSamplingProfiler.js +3 -9
- package/Libraries/PermissionsAndroid/NativePermissionsAndroid.js +4 -68
- package/Libraries/PermissionsAndroid/PermissionsAndroid.js +3 -3
- package/Libraries/Pressability/Pressability.js +12 -2
- package/Libraries/Pressability/usePressability.js +7 -0
- package/Libraries/PushNotificationIOS/NativePushNotificationManagerIOS.js +4 -70
- package/Libraries/PushNotificationIOS/PushNotificationIOS.js +45 -39
- package/Libraries/PushNotificationIOS/RCTPushNotificationManager.h +34 -5
- package/Libraries/PushNotificationIOS/RCTPushNotificationManager.mm +283 -231
- package/Libraries/PushNotificationIOS/React-RCTPushNotification.podspec +3 -2
- package/Libraries/ReactNative/AppContainer-dev.js +217 -0
- package/Libraries/ReactNative/AppContainer-prod.js +53 -0
- package/Libraries/ReactNative/AppContainer.js +6 -149
- package/Libraries/ReactNative/AppRegistry.js +3 -1
- package/Libraries/ReactNative/BridgelessUIManager.js +375 -128
- package/Libraries/ReactNative/FabricUIManager.js +6 -0
- package/Libraries/ReactNative/NativeHeadlessJsTaskSupport.js +3 -10
- package/Libraries/ReactNative/NativeI18nManager.js +3 -18
- package/Libraries/ReactNative/NativeUIManager.js +4 -112
- package/Libraries/ReactNative/PaperUIManager.js +8 -7
- package/Libraries/ReactNative/ReactFabricInternals.js +1 -1
- package/Libraries/ReactNative/ReactFabricPublicInstance/ReactFabricPublicInstance.js +24 -5
- package/Libraries/ReactNative/ReactNativeFeatureFlags.js +0 -45
- package/Libraries/ReactNative/RendererImplementation.js +11 -0
- package/Libraries/ReactNative/UIManager.d.ts +11 -34
- package/Libraries/ReactNative/UIManager.js +2 -23
- package/Libraries/ReactNative/UIManagerProperties.js +0 -2
- package/Libraries/ReactNative/__mocks__/FabricUIManager.js +23 -1
- package/Libraries/ReactNative/getNativeComponentAttributes.js +5 -1
- package/Libraries/ReactNative/renderApplication.js +9 -6
- package/Libraries/ReactPrivate/ReactNativePrivateInterface.js +6 -1
- package/Libraries/Renderer/implementations/ReactFabric-dev.js +24771 -21123
- package/Libraries/Renderer/implementations/ReactFabric-prod.js +4160 -3109
- package/Libraries/Renderer/implementations/ReactFabric-profiling.js +4384 -3322
- package/Libraries/Renderer/implementations/ReactNativeRenderer-dev.js +25194 -21398
- package/Libraries/Renderer/implementations/ReactNativeRenderer-prod.js +3763 -2636
- package/Libraries/Renderer/implementations/ReactNativeRenderer-profiling.js +4027 -2867
- package/Libraries/Renderer/shims/ReactNativeTypes.js +8 -9
- package/Libraries/Renderer/shims/ReactNativeViewConfigRegistry.js +7 -12
- package/Libraries/Settings/NativeSettingsManager.js +4 -16
- package/Libraries/Settings/React-RCTSettings.podspec +3 -2
- package/Libraries/Share/NativeShareModule.js +3 -13
- package/Libraries/StyleSheet/StyleSheet.d.ts +1 -20
- package/Libraries/StyleSheet/StyleSheet.js +5 -28
- package/Libraries/StyleSheet/StyleSheetTypes.d.ts +51 -7
- package/Libraries/StyleSheet/StyleSheetTypes.js +19 -11
- package/Libraries/StyleSheet/flattenStyle.js +2 -2
- package/Libraries/StyleSheet/normalizeColor.js +1 -1
- package/Libraries/StyleSheet/processAspectRatio.js +1 -1
- package/Libraries/StyleSheet/processFontVariant.js +1 -1
- package/Libraries/Text/Text/RCTTextShadowView.mm +1 -1
- package/Libraries/Text/Text/RCTTextView.mm +35 -11
- package/Libraries/Text/Text.js +0 -6
- package/Libraries/Text/TextAncestor.js +2 -3
- package/Libraries/Text/TextInput/RCTBaseTextInputShadowView.mm +1 -1
- package/Libraries/Text/TextInput/RCTBaseTextInputViewManager.mm +1 -1
- package/Libraries/Text/TextInput/RCTInputAccessoryViewManager.mm +0 -5
- package/Libraries/TurboModule/samples/NativeSampleTurboModule.js +4 -41
- package/Libraries/Types/ReactDevToolsTypes.js +58 -0
- package/Libraries/Types/UIManagerJSInterface.js +16 -0
- package/Libraries/Utilities/DebugEnvironment.js +1 -4
- package/Libraries/Utilities/Dimensions.js +8 -16
- package/Libraries/Utilities/GlobalPerformanceLogger.js +1 -2
- package/Libraries/Utilities/NativeAppearance.js +3 -26
- package/Libraries/Utilities/NativeDevLoadingView.js +3 -14
- package/Libraries/Utilities/NativeDeviceInfo.js +2 -47
- package/Libraries/Utilities/NativePlatformConstantsAndroid.js +3 -34
- package/Libraries/Utilities/NativePlatformConstantsIOS.js +3 -26
- package/Libraries/Utilities/PixelRatio.d.ts +4 -4
- package/Libraries/Utilities/Platform.android.js +4 -0
- package/Libraries/Utilities/Platform.d.ts +3 -0
- package/Libraries/Utilities/Platform.flow.js +7 -0
- package/Libraries/Utilities/Platform.ios.js +11 -0
- package/Libraries/Utilities/binaryToBase64.js +1 -1
- package/Libraries/Utilities/codegenNativeComponent.js +4 -6
- package/Libraries/Utilities/createPerformanceLogger.js +2 -74
- package/Libraries/Utilities/useMergeRefs.js +5 -9
- package/Libraries/Vibration/NativeVibration.js +2 -27
- package/Libraries/Vibration/React-RCTVibration.podspec +3 -2
- package/Libraries/Vibration/Vibration.js +8 -2
- package/Libraries/WebSocket/NativeWebSocketModule.js +4 -25
- package/Libraries/YellowBox/YellowBoxDeprecated.js +1 -1
- package/Libraries/vendor/emitter/EventEmitter.js +1 -0
- package/README.md +31 -11
- package/React/Base/RCTAssert.m +4 -4
- package/React/Base/RCTBridge+Inspector.h +30 -0
- package/React/Base/RCTBridge+Private.h +0 -6
- package/React/Base/RCTBridge.h +32 -13
- package/React/Base/RCTBridge.mm +113 -2
- package/React/Base/RCTBridgeDelegate.h +5 -1
- package/React/Base/RCTBridgeModule.h +24 -32
- package/React/Base/RCTBridgeProxy+Cxx.h +20 -0
- package/React/Base/RCTBridgeProxy.h +9 -1
- package/React/Base/RCTBridgeProxy.mm +40 -15
- package/React/Base/RCTBundleURLProvider.h +35 -46
- package/React/Base/RCTBundleURLProvider.mm +0 -34
- package/React/Base/RCTConstants.h +0 -12
- package/React/Base/RCTConstants.m +0 -31
- package/React/Base/RCTConvert.h +5 -2
- package/React/Base/{RCTConvert.m → RCTConvert.mm} +18 -8
- package/React/Base/RCTDefines.h +3 -3
- package/React/Base/RCTKeyCommands.m +12 -1
- package/React/Base/RCTModuleData.mm +0 -14
- package/React/Base/RCTRuntimeExecutorModule.h +18 -0
- package/React/Base/RCTUtils.h +9 -0
- package/React/Base/RCTUtils.m +37 -10
- package/React/Base/RCTVersion.m +5 -5
- package/React/Base/Surface/SurfaceHostingView/RCTSurfaceHostingProxyRootView.h +9 -0
- package/React/Base/Surface/SurfaceHostingView/RCTSurfaceHostingProxyRootView.mm +25 -0
- package/React/Base/Surface/SurfaceHostingView/RCTSurfaceHostingView.h +7 -0
- package/React/Base/Surface/SurfaceHostingView/RCTSurfaceHostingView.mm +17 -2
- package/React/CoreModules/RCTActionSheetManager.mm +140 -140
- package/React/CoreModules/RCTAlertController.mm +3 -26
- package/React/CoreModules/RCTAlertManager.mm +94 -93
- package/React/CoreModules/RCTAppState.mm +2 -6
- package/React/CoreModules/RCTAppearance.mm +1 -9
- package/React/CoreModules/RCTDevLoadingView.mm +6 -9
- package/React/CoreModules/RCTDevMenu.h +2 -0
- package/React/CoreModules/RCTDevMenu.mm +37 -19
- package/React/CoreModules/RCTDevSettings.mm +11 -5
- package/React/CoreModules/RCTDeviceInfo.mm +15 -16
- package/React/CoreModules/RCTPerfMonitor.mm +2 -14
- package/React/CoreModules/RCTPlatform.mm +19 -12
- package/React/CoreModules/RCTRedBox.mm +130 -111
- package/React/CoreModules/RCTStatusBarManager.mm +30 -22
- package/React/CoreModules/RCTTVNavigationEventEmitter.mm +1 -4
- package/React/CoreModules/RCTTiming.mm +18 -1
- package/React/CoreModules/React-CoreModules.podspec +10 -3
- package/React/CxxBridge/RCTCxxBridge.mm +24 -13
- package/React/DevSupport/RCTInspectorDevServerHelper.h +2 -1
- package/React/DevSupport/RCTInspectorDevServerHelper.mm +26 -5
- package/React/Fabric/Mounting/ComponentViews/ActivityIndicator/RCTActivityIndicatorViewComponentView.mm +1 -1
- package/React/Fabric/Mounting/ComponentViews/DebuggingOverlay/RCTDebuggingOverlayComponentView.h +16 -0
- package/React/Fabric/Mounting/ComponentViews/DebuggingOverlay/RCTDebuggingOverlayComponentView.mm +73 -0
- package/React/Fabric/Mounting/ComponentViews/Image/RCTImageComponentView.mm +8 -10
- package/React/Fabric/Mounting/ComponentViews/InputAccessory/RCTInputAccessoryComponentView.mm +1 -2
- package/React/Fabric/Mounting/ComponentViews/LegacyViewManagerInterop/RCTLegacyViewManagerInteropComponentView.h +6 -0
- package/React/Fabric/Mounting/ComponentViews/LegacyViewManagerInterop/RCTLegacyViewManagerInteropComponentView.mm +60 -14
- package/React/Fabric/Mounting/ComponentViews/LegacyViewManagerInterop/RCTLegacyViewManagerInteropCoordinatorAdapter.mm +93 -3
- package/React/Fabric/Mounting/ComponentViews/Modal/RCTFabricModalHostViewController.mm +2 -2
- package/React/Fabric/Mounting/ComponentViews/Modal/RCTModalHostViewComponentView.mm +6 -4
- package/React/Fabric/Mounting/ComponentViews/RCTFabricComponentsPlugins.h +1 -0
- package/React/Fabric/Mounting/ComponentViews/RCTFabricComponentsPlugins.mm +1 -0
- package/React/Fabric/Mounting/ComponentViews/Root/RCTRootComponentView.mm +2 -5
- package/React/Fabric/Mounting/ComponentViews/SafeAreaView/RCTSafeAreaViewComponentView.mm +1 -2
- package/React/Fabric/Mounting/ComponentViews/ScrollView/RCTPullToRefreshViewComponentView.mm +1 -2
- package/React/Fabric/Mounting/ComponentViews/ScrollView/RCTScrollViewComponentView.mm +30 -8
- package/React/Fabric/Mounting/ComponentViews/Switch/RCTSwitchComponentView.mm +1 -2
- package/React/Fabric/Mounting/ComponentViews/Text/RCTParagraphComponentView.mm +36 -14
- package/React/Fabric/Mounting/ComponentViews/TextInput/RCTTextInputComponentView.mm +2 -3
- package/React/Fabric/Mounting/ComponentViews/UnimplementedComponent/RCTUnimplementedNativeComponentView.mm +1 -2
- package/React/Fabric/Mounting/ComponentViews/UnimplementedView/RCTUnimplementedViewComponentView.mm +1 -2
- package/React/Fabric/Mounting/ComponentViews/View/RCTViewComponentView.mm +72 -30
- package/React/Fabric/Mounting/RCTComponentViewClassDescriptor.h +5 -0
- package/React/Fabric/Mounting/RCTComponentViewDescriptor.h +1 -0
- package/React/Fabric/Mounting/RCTComponentViewFactory.mm +9 -17
- package/React/Fabric/Mounting/RCTComponentViewProtocol.h +2 -2
- package/React/Fabric/Mounting/RCTComponentViewRegistry.mm +1 -1
- package/React/Fabric/Mounting/RCTMountingManager.mm +3 -4
- package/React/Fabric/RCTConversions.h +2 -18
- package/React/Fabric/RCTSurfacePointerHandler.mm +6 -107
- package/React/Fabric/RCTSurfacePresenter.mm +2 -21
- package/{Libraries/AppDelegate/RCTLegacyInteropComponents.h → React/Inspector/RCTCxxInspectorPackagerConnection.h} +5 -6
- package/React/Inspector/RCTCxxInspectorPackagerConnection.mm +69 -0
- package/React/Inspector/RCTCxxInspectorPackagerConnectionDelegate.h +47 -0
- package/React/Inspector/RCTCxxInspectorPackagerConnectionDelegate.mm +48 -0
- package/React/Inspector/RCTCxxInspectorWebSocketAdapter.h +23 -0
- package/React/Inspector/RCTCxxInspectorWebSocketAdapter.mm +92 -0
- package/React/Inspector/RCTInspector.mm +2 -2
- package/React/Inspector/RCTInspectorPackagerConnection.h +4 -9
- package/React/Inspector/RCTInspectorPackagerConnection.m +2 -28
- package/React/Modules/RCTEventEmitter.h +0 -2
- package/React/Modules/RCTEventEmitter.m +0 -12
- package/React/Modules/RCTUIManager.h +32 -0
- package/React/Modules/RCTUIManager.m +87 -58
- package/React/React-RCTFabric.podspec +7 -5
- package/React/Tests/Text/RCTParagraphComponentViewTests.mm +24 -24
- package/React/UIUtils/RCTUIUtils.h +0 -4
- package/React/UIUtils/RCTUIUtils.m +1 -27
- package/React/Views/RCTComponentData.m +8 -9
- package/React/Views/RCTConvert+Transform.h +4 -1
- package/React/Views/RCTConvert+Transform.m +7 -0
- package/React/Views/{RCTTransformOrigin.h → RCTCursor.h} +4 -6
- package/React/Views/RCTDebuggingOverlay.h +27 -0
- package/React/Views/RCTDebuggingOverlay.m +122 -0
- package/{ReactCommon/hermes/executor/JSITracing.h → React/Views/RCTDebuggingOverlayManager.h} +3 -7
- package/React/Views/RCTDebuggingOverlayManager.m +64 -0
- package/React/Views/RCTModalHostViewController.m +2 -2
- package/React/Views/RCTModalHostViewManager.m +6 -1
- package/React/Views/RCTShadowView.m +7 -7
- package/React/Views/RCTView.h +3 -0
- package/React/Views/RCTView.m +31 -1
- package/React/Views/RCTViewManager.m +3 -9
- package/React/Views/RCTWrapperViewController.m +0 -1
- package/React/Views/ScrollView/RCTScrollView.m +3 -4
- package/React/Views/ScrollView/RCTScrollViewManager.m +2 -0
- package/React/Views/UIView+React.h +7 -1
- package/React/third-party.xcconfig +2 -2
- package/React-Core.podspec +11 -6
- package/ReactAndroid/api/ReactAndroid.api +7700 -0
- package/ReactAndroid/build.gradle.kts +815 -0
- package/ReactAndroid/cmake-utils/ReactNative-application.cmake +19 -1
- package/ReactAndroid/cmake-utils/default-app-setup/OnLoad.cpp +35 -7
- package/ReactAndroid/external-artifacts/build.gradle.kts +1 -1
- package/ReactAndroid/gradle.properties +21 -2
- package/ReactAndroid/hermes-engine/build.gradle.kts +322 -0
- package/ReactAndroid/proguard-rules.pro +8 -1
- package/ReactAndroid/publish.gradle +3 -8
- package/ReactAndroid/src/main/AndroidManifest.xml +1 -1
- package/ReactAndroid/src/main/java/com/facebook/annotationprocessors/common/ProcessorBase.java +24 -0
- package/ReactAndroid/src/main/java/com/facebook/react/BaseReactPackage.java +159 -0
- package/ReactAndroid/src/main/java/com/facebook/react/CompositeReactPackage.java +9 -4
- package/ReactAndroid/src/main/java/com/facebook/react/CompositeReactPackageTurboModuleManagerDelegate.java +4 -1
- package/ReactAndroid/src/main/java/com/facebook/react/CoreModulesPackage.java +2 -3
- package/ReactAndroid/src/main/java/com/facebook/react/DebugCorePackage.java +6 -8
- package/ReactAndroid/src/main/java/com/facebook/react/EagerModuleProvider.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/{JSEngineResolutionAlgorithm.java → JSEngineResolutionAlgorithm.kt} +5 -6
- package/ReactAndroid/src/main/java/com/facebook/react/LazyReactPackage.java +3 -15
- package/ReactAndroid/src/main/java/com/facebook/react/MemoryPressureRouter.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/NativeModuleRegistryBuilder.java +3 -6
- package/ReactAndroid/src/main/java/com/facebook/react/ReactActivity.java +7 -2
- package/ReactAndroid/src/main/java/com/facebook/react/ReactActivityDelegate.java +18 -43
- package/ReactAndroid/src/main/java/com/facebook/react/ReactApplication.kt +3 -6
- package/ReactAndroid/src/main/java/com/facebook/react/ReactDelegate.java +121 -19
- package/ReactAndroid/src/main/java/com/facebook/react/ReactFragment.java +2 -6
- package/ReactAndroid/src/main/java/com/facebook/react/ReactHost.kt +45 -18
- package/ReactAndroid/src/main/java/com/facebook/react/{ReactInstanceEventListener.java → ReactInstanceEventListener.kt} +4 -8
- package/ReactAndroid/src/main/java/com/facebook/react/ReactInstanceManager.java +61 -52
- package/ReactAndroid/src/main/java/com/facebook/react/ReactInstanceManagerBuilder.java +38 -31
- package/ReactAndroid/src/main/java/com/facebook/react/ReactNativeHost.java +19 -5
- package/ReactAndroid/src/main/java/com/facebook/react/ReactPackageHelper.java +6 -20
- package/ReactAndroid/src/main/java/com/facebook/react/ReactPackageTurboModuleManagerDelegate.java +44 -25
- package/ReactAndroid/src/main/java/com/facebook/react/ReactRootView.java +11 -34
- package/ReactAndroid/src/main/java/com/facebook/react/TurboReactPackage.java +3 -148
- package/ReactAndroid/src/main/java/com/facebook/react/animated/AnimatedNode.java +3 -1
- package/ReactAndroid/src/main/java/com/facebook/react/animated/AnimatedNodeValueListener.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/animated/AnimatedNodeWithUpdateableConfig.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/animated/DecayAnimation.java +3 -1
- package/ReactAndroid/src/main/java/com/facebook/react/animated/DiffClampAnimatedNode.java +3 -1
- package/ReactAndroid/src/main/java/com/facebook/react/animated/EventAnimationDriver.java +37 -9
- package/ReactAndroid/src/main/java/com/facebook/react/animated/ModulusAnimatedNode.java +3 -1
- package/ReactAndroid/src/main/java/com/facebook/react/animated/NativeAnimatedModule.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/animated/NativeAnimatedNodesManager.java +27 -8
- package/ReactAndroid/src/main/java/com/facebook/react/animated/ObjectAnimatedNode.java +3 -1
- package/ReactAndroid/src/main/java/com/facebook/react/animated/SpringAnimation.java +3 -1
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/BaseJavaModule.java +61 -5
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/CatalystInstance.java +25 -6
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/CatalystInstanceImpl.java +81 -94
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/CxxModuleWrapper.java +0 -9
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/CxxModuleWrapperBase.java +0 -3
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/DynamicFromArray.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/DynamicFromMap.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/JSIModule.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/JSIModuleHolder.java +2 -2
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/JSIModuleRegistry.java +3 -3
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/JSInstance.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/JavaMethodWrapper.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/JavaModuleWrapper.java +12 -15
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/ModuleHolder.java +3 -3
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/NativeArgumentsParseException.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/NativeModule.java +13 -16
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/PerformanceCounter.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/ReactContext.java +31 -6
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/ReactContextBaseJavaModule.java +9 -48
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/ReactMarkerConstants.java +0 -2
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/UIManager.java +8 -3
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/{UIManagerListener.java → UIManagerListener.kt} +6 -6
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/UIManagerProvider.kt +22 -0
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/UiThreadUtil.java +22 -10
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/interop/InteropModuleRegistry.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/queue/MessageQueueThreadHandler.java +0 -11
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/queue/MessageQueueThreadImpl.java +1 -2
- package/ReactAndroid/src/main/java/com/facebook/react/common/DebugServerException.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/common/JavascriptException.java +3 -1
- package/ReactAndroid/src/main/java/com/facebook/react/common/LifecycleState.java +3 -0
- package/ReactAndroid/src/main/java/com/facebook/react/common/LongArray.java +3 -0
- package/ReactAndroid/src/main/java/com/facebook/react/common/MapBuilder.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/common/ReactConstants.java +11 -0
- package/ReactAndroid/src/main/java/com/facebook/react/common/ShakeDetector.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/common/SingleThreadAsserter.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/common/StandardCharsets.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/common/SystemClock.java +3 -0
- package/ReactAndroid/src/main/java/com/facebook/react/common/annotations/DeprecatedInNewArchitecture.kt +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/common/annotations/FrameworkAPI.kt +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/common/annotations/StableReactNativeAPI.kt +13 -0
- package/ReactAndroid/src/main/java/com/facebook/react/common/annotations/UnstableReactNativeAPI.kt +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/common/annotations/VisibleForTesting.kt +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/common/assets/ReactFontManager.java +6 -6
- package/ReactAndroid/src/main/java/com/facebook/react/common/futures/SimpleSettableFuture.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/common/mapbuffer/MapBuffer.kt +25 -22
- package/ReactAndroid/src/main/java/com/facebook/react/common/mapbuffer/MapBufferSoLoader.kt +4 -2
- package/ReactAndroid/src/main/java/com/facebook/react/common/mapbuffer/ReadableMapBuffer.kt +8 -6
- package/ReactAndroid/src/main/java/com/facebook/react/common/mapbuffer/WritableMapBuffer.kt +9 -7
- package/ReactAndroid/src/main/java/com/facebook/react/common/network/OkHttpCallUtil.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/config/ReactFeatureFlags.java +30 -55
- package/ReactAndroid/src/main/java/com/facebook/react/defaults/DefaultComponentsRegistry.kt +11 -4
- package/ReactAndroid/src/main/java/com/facebook/react/defaults/DefaultNewArchitectureEntryPoint.kt +39 -31
- package/ReactAndroid/src/main/java/com/facebook/react/defaults/DefaultReactActivityDelegate.kt +5 -3
- package/ReactAndroid/src/main/java/com/facebook/react/defaults/DefaultReactHost.kt +5 -5
- package/ReactAndroid/src/main/java/com/facebook/react/defaults/DefaultReactHostDelegate.kt +7 -8
- package/ReactAndroid/src/main/java/com/facebook/react/defaults/DefaultReactNativeHost.kt +32 -5
- package/ReactAndroid/src/main/java/com/facebook/react/defaults/DefaultSoLoader.kt +26 -0
- package/ReactAndroid/src/main/java/com/facebook/react/defaults/DefaultTurboModuleManagerDelegate.kt +51 -7
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/BridgeDevSupportManager.java +2 -1
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/CxxInspectorPackagerConnection.java +142 -0
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/DebugOverlayController.java +15 -27
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/DefaultDevSupportManagerFactory.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/DevInternalSettings.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/DevServerHelper.java +10 -9
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/DevSettingsActivity.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/DevSupportManagerBase.java +50 -27
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/DevSupportSoLoader.java +24 -0
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/DoubleTapReloadRecognizer.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/FpsView.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/IInspectorPackagerConnection.java +16 -0
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/InspectorFlags.java +28 -0
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/InspectorPackagerConnection.java +2 -26
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/JSCHeapCapture.java +0 -4
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/LogBoxDialog.java +3 -1
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/LogBoxDialogSurfaceDelegate.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/LogBoxModule.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/MultipartStreamReader.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/PackagerStatusCheck.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/PerftestDevSupportManager.java +2 -3
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/RedBoxDialogSurfaceDelegate.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/ViewHierarchyUtil.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/WindowOverlayCompat.java +4 -7
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/interfaces/ErrorType.java +3 -0
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/Binding.java +12 -15
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/BindingImpl.java +2 -3
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/ComponentFactory.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/CoreComponentsRegistry.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/DevToolsReactPerfLogger.java +23 -81
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/EmptyReactNativeConfig.kt +36 -0
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/FabricComponents.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/FabricSoLoader.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/FabricUIManager.java +82 -64
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/FabricUIManagerProviderImpl.java +65 -0
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/GuardedFrameCallback.java +4 -2
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/LongStreamingStats.java +76 -0
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/ReactNativeConfig.kt +7 -7
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/StateWrapperImpl.java +16 -0
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/SurfaceHandlerBinding.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/events/EventBeatManager.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/events/FabricEventEmitter.java +7 -3
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/internal/interop/InteropUiBlockListener.kt +68 -0
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/interop/UIBlock.kt +27 -0
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/interop/UIBlockViewResolver.kt +29 -0
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/mounting/LayoutMetricsConversions.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/mounting/MountItemDispatcher.java +32 -28
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/mounting/MountingManager.java +4 -1
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/mounting/SurfaceMountingManager.java +77 -96
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/mounting/mountitems/DispatchCommandMountItem.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/mounting/mountitems/DispatchIntCommandMountItem.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/mounting/mountitems/DispatchStringCommandMountItem.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/mounting/mountitems/FabricNameComponentMapping.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/mounting/mountitems/IntBufferBatchMountItem.java +9 -16
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/mounting/mountitems/MountItemFactory.java +4 -1
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/mounting/mountitems/PreAllocateViewMountItem.java +5 -2
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/mounting/mountitems/SendAccessibilityEvent.java +3 -1
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/mounting/mountitems/SendAccessibilityEventMountItem.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/flipper/ReactNativeFlipper.kt +34 -0
- package/ReactAndroid/src/main/java/com/facebook/react/interfaces/TaskInterface.kt +8 -8
- package/ReactAndroid/src/main/java/com/facebook/react/interfaces/exceptionmanager/ReactJsExceptionHandler.kt +2 -2
- package/ReactAndroid/src/main/java/com/facebook/react/interfaces/fabric/ReactSurface.kt +11 -11
- package/ReactAndroid/src/main/java/com/facebook/react/interfaces/fabric/SurfaceHandler.kt +10 -10
- package/ReactAndroid/src/main/java/com/facebook/react/internal/AndroidChoreographerProvider.java +41 -0
- package/ReactAndroid/src/main/java/com/facebook/react/internal/ChoreographerProvider.java +30 -0
- package/ReactAndroid/src/main/java/com/facebook/react/internal/featureflags/ReactNativeFeatureFlags.kt +135 -0
- package/ReactAndroid/src/main/java/com/facebook/react/internal/featureflags/ReactNativeFeatureFlagsAccessor.kt +14 -0
- package/ReactAndroid/src/main/java/com/facebook/react/internal/featureflags/ReactNativeFeatureFlagsCxxAccessor.kt +128 -0
- package/ReactAndroid/src/main/java/com/facebook/react/internal/featureflags/ReactNativeFeatureFlagsCxxInterop.kt +54 -0
- package/ReactAndroid/src/main/java/com/facebook/react/internal/featureflags/ReactNativeFeatureFlagsDefaults.kt +45 -0
- package/ReactAndroid/src/main/java/com/facebook/react/internal/featureflags/ReactNativeFeatureFlagsForTests.kt +14 -0
- package/ReactAndroid/src/main/java/com/facebook/react/internal/featureflags/ReactNativeFeatureFlagsLocalAccessor.kt +151 -0
- package/ReactAndroid/src/main/java/com/facebook/react/internal/featureflags/ReactNativeFeatureFlagsProvider.kt +45 -0
- package/ReactAndroid/src/main/java/com/facebook/react/internal/interop/InteropEvent.kt +27 -0
- package/ReactAndroid/src/main/java/com/facebook/react/internal/interop/InteropEventEmitter.kt +55 -0
- package/ReactAndroid/src/main/java/com/facebook/react/{turbomodule → internal/turbomodule}/core/NativeModuleSoLoader.kt +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/{turbomodule → internal/turbomodule}/core/TurboModuleInteropUtils.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/{turbomodule → internal/turbomodule}/core/TurboModuleManager.java +13 -10
- package/ReactAndroid/src/main/java/com/facebook/react/{turbomodule → internal/turbomodule}/core/TurboModuleManagerDelegate.java +15 -1
- package/ReactAndroid/src/main/java/com/facebook/react/{turbomodule → internal/turbomodule}/core/TurboModulePerfLogger.java +3 -1
- package/ReactAndroid/src/main/java/com/facebook/react/{turbomodule → internal/turbomodule}/core/interfaces/TurboModuleRegistry.kt +12 -6
- package/ReactAndroid/src/main/java/com/facebook/react/jscexecutor/JSCExecutor.kt +3 -3
- package/ReactAndroid/src/main/java/com/facebook/react/jscexecutor/JSCExecutorFactory.kt +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/jstasks/LinearCountingRetryPolicy.java +3 -0
- package/ReactAndroid/src/main/java/com/facebook/react/jstasks/NoRetryPolicy.java +4 -1
- package/ReactAndroid/src/main/java/com/facebook/react/module/annotations/ReactModule.java +3 -3
- package/ReactAndroid/src/main/java/com/facebook/react/module/model/ReactModuleInfo.java +10 -0
- package/ReactAndroid/src/main/java/com/facebook/react/module/processing/ReactModuleSpecProcessor.java +3 -3
- package/ReactAndroid/src/main/java/com/facebook/react/modules/accessibilityinfo/AccessibilityInfoModule.java +2 -3
- package/ReactAndroid/src/main/java/com/facebook/react/modules/blob/BlobProvider.java +4 -3
- package/ReactAndroid/src/main/java/com/facebook/react/modules/common/ModuleDataCleaner.java +7 -7
- package/ReactAndroid/src/main/java/com/facebook/react/modules/core/ChoreographerCompat.java +3 -98
- package/ReactAndroid/src/main/java/com/facebook/react/modules/core/JavaTimerManager.java +3 -2
- package/ReactAndroid/src/main/java/com/facebook/react/modules/core/ReactChoreographer.java +57 -71
- package/ReactAndroid/src/main/java/com/facebook/react/modules/debug/AnimationsDebugModule.java +3 -2
- package/ReactAndroid/src/main/java/com/facebook/react/modules/debug/DidJSUpdateUiDuringFrameDetector.java +4 -4
- package/ReactAndroid/src/main/java/com/facebook/react/modules/debug/FpsDebugFrameCallback.java +37 -29
- package/ReactAndroid/src/main/java/com/facebook/react/modules/fresco/ReactNetworkImageRequest.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/modules/network/CountingOutputStream.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/modules/network/HeaderUtil.java +1 -15
- package/ReactAndroid/src/main/java/com/facebook/react/modules/network/NetworkingModule.java +2 -2
- package/ReactAndroid/src/main/java/com/facebook/react/modules/network/ProgressRequestBody.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/modules/network/ProgressResponseBody.java +2 -2
- package/ReactAndroid/src/main/java/com/facebook/react/modules/network/ProgressiveStringDecoder.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/modules/network/ReactCookieJarContainer.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/modules/network/RequestBodyUtil.java +5 -22
- package/ReactAndroid/src/main/java/com/facebook/react/modules/permissions/PermissionsModule.java +8 -31
- package/ReactAndroid/src/main/java/com/facebook/react/modules/statusbar/StatusBarModule.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/modules/systeminfo/AndroidInfoHelpers.java +0 -9
- package/ReactAndroid/src/main/java/com/facebook/react/modules/systeminfo/ReactNativeVersion.java +5 -5
- package/ReactAndroid/src/main/java/com/facebook/react/packagerconnection/FileIoHandler.java +4 -2
- package/ReactAndroid/src/main/java/com/facebook/react/packagerconnection/NotificationOnlyHandler.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/packagerconnection/PackagerConnectionSettings.java +2 -4
- package/ReactAndroid/src/main/java/com/facebook/react/packagerconnection/RequestOnlyHandler.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/processing/ReactPropertyProcessor.java +4 -4
- package/ReactAndroid/src/main/java/com/facebook/react/reactperflogger/NativeModulePerfLogger.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/runtime/BindingsInstaller.kt +2 -2
- package/ReactAndroid/src/main/java/com/facebook/react/runtime/BridgelessCatalystInstance.kt +201 -0
- package/ReactAndroid/src/main/java/com/facebook/react/runtime/BridgelessDevSupportManager.java +16 -3
- package/ReactAndroid/src/main/java/com/facebook/react/runtime/BridgelessReactContext.java +28 -15
- package/ReactAndroid/src/main/java/com/facebook/react/runtime/CoreReactPackage.java +15 -10
- package/ReactAndroid/src/main/java/com/facebook/react/runtime/JSCInstance.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/runtime/{JSEngineInstance.java → JSRuntimeFactory.java} +2 -2
- package/ReactAndroid/src/main/java/com/facebook/react/runtime/ReactHostDelegate.kt +16 -14
- package/ReactAndroid/src/main/java/com/facebook/react/runtime/ReactHostImpl.java +223 -349
- package/ReactAndroid/src/main/java/com/facebook/react/runtime/ReactInstance.java +166 -126
- package/ReactAndroid/src/main/java/com/facebook/react/runtime/cxxreactpackage/CxxReactPackage.kt +31 -0
- package/ReactAndroid/src/main/java/com/facebook/react/runtime/hermes/HermesInstance.kt +8 -4
- package/ReactAndroid/src/main/java/com/facebook/react/runtime/internal/bolts/AggregateException.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/runtime/internal/bolts/CancellationTokenRegistration.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/runtime/internal/bolts/Capture.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/runtime/internal/bolts/ExecutorException.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/runtime/internal/bolts/Task.java +2 -2
- package/ReactAndroid/src/main/java/com/facebook/react/runtime/internal/bolts/UnobservedErrorNotifier.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/runtime/internal/bolts/UnobservedTaskException.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/shell/MainPackageConfig.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/shell/MainReactPackage.java +5 -4
- package/ReactAndroid/src/main/java/com/facebook/react/touch/JSResponderHandler.kt +73 -0
- package/ReactAndroid/src/main/java/com/facebook/react/touch/{OnInterceptTouchEventListener.java → OnInterceptTouchEventListener.kt} +8 -8
- package/ReactAndroid/src/main/java/com/facebook/react/touch/ReactHitSlopView.kt +18 -0
- package/ReactAndroid/src/main/java/com/facebook/react/touch/ReactInterceptingViewGroup.kt +31 -0
- package/ReactAndroid/src/main/java/com/facebook/react/turbomodule/core/CallInvokerHolderImpl.java +5 -0
- package/ReactAndroid/src/main/java/com/facebook/react/turbomodule/core/NativeMethodCallInvokerHolderImpl.java +5 -0
- package/ReactAndroid/src/main/java/com/facebook/react/turbomodule/core/interfaces/CallInvokerHolder.kt +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/turbomodule/core/interfaces/NativeMethodCallInvokerHolder.kt +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/turbomodule/core/interfaces/TurboModule.kt +3 -3
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/GuardedFrameCallback.java +2 -2
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/IViewGroupManager.java +10 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/JSTouchDispatcher.java +3 -2
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/LayoutShadowNode.java +7 -7
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/NativeViewHierarchyManager.java +13 -1
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/NoSuchNativeViewException.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/ReactAccessibilityDelegate.java +0 -5
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/ReactCompoundViewGroup.java +4 -4
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/ReactRoot.java +1 -4
- package/ReactAndroid/src/main/java/com/facebook/react/{surface → uimanager}/ReactStage.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/ShadowNodeRegistry.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/ThemedReactContext.java +4 -5
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/UIConstantsProviderManager.java +35 -3
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/UIImplementation.java +7 -21
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/UIManagerHelper.java +2 -3
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/UIManagerModule.java +24 -36
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/UIManagerModuleConstantsHelper.java +7 -20
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/UIViewOperationQueue.java +29 -43
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/ViewGroupManager.java +0 -8
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/ViewHierarchyDumper.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/ViewManagerRegistry.java +17 -1
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/YogaNodePool.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/annotations/ReactProp.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/annotations/ReactPropGroup.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/annotations/ReactPropertyHolder.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/common/UIManagerType.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/common/ViewUtil.java +3 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/debug/NotThreadSafeViewHierarchyUpdateDebugListener.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/BlackHoleEventDispatcher.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/ContentSizeChangeEvent.java +8 -1
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/Event.java +14 -27
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/EventDispatcherImpl.java +10 -4
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/FabricEventDispatcher.java +5 -3
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/NativeGestureUtil.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/PointerEventHelper.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/RCTEventEmitter.java +8 -3
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/RCTModernEventEmitter.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/ReactEventEmitter.java +14 -15
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/TouchEvent.java +5 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/TouchEventCoalescingKeyHelper.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/TouchEventType.java +3 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/TouchesHelper.java +29 -23
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/layoutanimation/AnimatedPropertyType.java +4 -1
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/layoutanimation/BaseLayoutAnimation.java +3 -1
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/layoutanimation/InterpolatorType.java +3 -1
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/layoutanimation/LayoutAnimationController.java +3 -9
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/layoutanimation/LayoutAnimationType.java +4 -1
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/layoutanimation/LayoutCreateAnimation.java +4 -1
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/layoutanimation/LayoutDeleteAnimation.java +4 -1
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/layoutanimation/LayoutUpdateAnimation.java +3 -1
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/layoutanimation/OpacityAnimation.java +3 -1
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/layoutanimation/PositionAndSizeAnimation.java +3 -1
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/layoutanimation/SimpleSpringInterpolator.java +3 -1
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/util/ReactFindViewUtil.java +3 -2
- package/ReactAndroid/src/main/java/com/facebook/react/util/JSStackTrace.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/util/RNLog.java +7 -3
- package/ReactAndroid/src/main/java/com/facebook/react/views/common/ContextUtils.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/common/ViewUtils.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/debuggingoverlay/DebuggingOverlay.java +97 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/debuggingoverlay/DebuggingOverlayManager.java +162 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/debuggingoverlay/TraceUpdate.java +37 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/drawer/ReactDrawerLayout.java +3 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/drawer/ReactDrawerLayoutManager.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/drawer/events/DrawerClosedEvent.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/drawer/events/DrawerOpenedEvent.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/drawer/events/DrawerSlideEvent.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/drawer/events/DrawerStateChangedEvent.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/image/ImageLoadEvent.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/image/ImageResizeMethod.java +3 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/image/ImageResizeMode.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/image/ReactImageDownloadListener.java +3 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/image/ScaleTypeStartInside.java +4 -2
- package/ReactAndroid/src/main/java/com/facebook/react/views/imagehelper/MultiSourceHelper.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/imagehelper/ResourceDrawableIdHelper.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/modal/ModalHostHelper.java +3 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/modal/ModalHostShadowNode.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/modal/ReactModalHostView.java +28 -13
- package/ReactAndroid/src/main/java/com/facebook/react/views/modal/RequestCloseEvent.java +3 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/modal/ShowEvent.java +3 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/progressbar/ProgressBarContainerView.java +4 -2
- package/ReactAndroid/src/main/java/com/facebook/react/views/progressbar/ProgressBarShadowNode.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/progressbar/ReactProgressBarViewManager.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/MaintainVisibleScrollPositionHelper.java +3 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/OnScrollDispatchHelper.java +4 -2
- package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/ReactHorizontalScrollContainerView.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/ReactHorizontalScrollContainerViewManager.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/ReactScrollView.java +15 -14
- package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/ReactScrollViewAccessibilityDelegate.java +3 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/ReactScrollViewHelper.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/ScrollEvent.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/ScrollEventType.java +3 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/VelocityHelper.java +3 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/swiperefresh/ReactSwipeRefreshLayout.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/swiperefresh/RefreshEvent.java +3 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/switchview/ReactSwitchEvent.java +3 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/BasicTextAttributeProvider.kt +48 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/EffectiveTextAttributeProvider.kt +22 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/HierarchicTextAttributeProvider.kt +63 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/ReactBaseTextShadowNode.java +229 -31
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/ReactTextAnchorViewManager.java +1 -6
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/ReactTextShadowNode.java +40 -52
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/ReactTextUpdate.java +5 -6
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/ReactTextView.java +24 -30
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/ReactTextViewManager.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/ReactTypefaceUtils.java +3 -2
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/TextAttributeProps.java +119 -22
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/TextAttributes.java +4 -2
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/TextLayoutManager.java +66 -54
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/TextLayoutManagerMapBuffer.java +61 -54
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/TextLayoutUtils.kt +379 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/TextTransform.java +2 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/fragments/BridgeTextFragment.kt +39 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/fragments/BridgeTextFragmentList.kt +18 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/fragments/MapBufferTextFragment.kt +42 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/fragments/MapBufferTextFragmentList.kt +19 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/fragments/TextFragment.kt +29 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/fragments/TextFragmentList.kt +15 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/frescosupport/FrescoBasedReactTextInlineImageShadowNode.java +3 -3
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/frescosupport/FrescoBasedReactTextInlineImageSpan.java +2 -2
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/{ReactTextInlineImageShadowNode.java → internal/ReactTextInlineImageShadowNode.java} +2 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/{CustomLetterSpacingSpan.java → internal/span/CustomLetterSpacingSpan.java} +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/{CustomLineHeightSpan.java → internal/span/CustomLineHeightSpan.java} +9 -6
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/{CustomStyleSpan.java → internal/span/CustomStyleSpan.java} +16 -17
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/{ReactAbsoluteSizeSpan.java → internal/span/ReactAbsoluteSizeSpan.java} +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/{ReactBackgroundColorSpan.java → internal/span/ReactBackgroundColorSpan.java} +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/{ReactClickableSpan.java → internal/span/ReactClickableSpan.java} +5 -3
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/{ReactForegroundColorSpan.java → internal/span/ReactForegroundColorSpan.java} +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/{ReactSpan.java → internal/span/ReactSpan.java} +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/{ReactStrikethroughSpan.java → internal/span/ReactStrikethroughSpan.java} +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/{ReactTagSpan.java → internal/span/ReactTagSpan.java} +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/{ReactUnderlineSpan.java → internal/span/ReactUnderlineSpan.java} +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/{SetSpanOperation.java → internal/span/SetSpanOperation.java} +9 -4
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/{ShadowStyleSpan.java → internal/span/ShadowStyleSpan.java} +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/{TextInlineImageSpan.java → internal/span/TextInlineImageSpan.java} +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/{TextInlineViewPlaceholderSpan.java → internal/span/TextInlineViewPlaceholderSpan.java} +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/textinput/ReactEditText.java +38 -54
- package/ReactAndroid/src/main/java/com/facebook/react/views/textinput/ReactTextInputKeyPressEvent.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/textinput/ReactTextInputLocalData.java +2 -10
- package/ReactAndroid/src/main/java/com/facebook/react/views/textinput/ReactTextInputManager.java +174 -123
- package/ReactAndroid/src/main/java/com/facebook/react/views/textinput/ReactTextInputShadowNode.java +5 -16
- package/ReactAndroid/src/main/java/com/facebook/react/views/textinput/ScrollWatcher.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/textinput/SelectionWatcher.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/unimplementedview/ReactUnimplementedView.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/view/CanvasUtil.java +4 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/view/ColorUtil.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/view/MeasureUtil.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/view/ReactClippingViewManager.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/view/ReactDrawableHelper.java +1 -4
- package/ReactAndroid/src/main/java/com/facebook/react/views/view/ReactViewBackgroundDrawable.java +1 -3
- package/ReactAndroid/src/main/java/com/facebook/react/views/view/ReactViewBackgroundManager.java +3 -3
- package/ReactAndroid/src/main/java/com/facebook/react/views/view/ReactViewGroup.java +11 -4
- package/ReactAndroid/src/main/java/com/facebook/react/views/view/ReactViewManager.java +0 -3
- package/ReactAndroid/src/main/java/com/facebook/react/views/view/ViewGroupClickEvent.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/yoga/YogaAlign.java +3 -1
- package/ReactAndroid/src/main/java/com/facebook/yoga/YogaConfig.java +1 -3
- package/ReactAndroid/src/main/java/com/facebook/yoga/YogaConfigJNIBase.java +1 -5
- package/ReactAndroid/src/main/java/com/facebook/yoga/YogaErrata.java +4 -0
- package/ReactAndroid/src/main/java/com/facebook/yoga/YogaExperimentalFeature.java +1 -3
- package/ReactAndroid/src/main/java/com/facebook/yoga/YogaNative.java +2 -4
- package/ReactAndroid/src/main/java/com/facebook/yoga/YogaNode.java +2 -2
- package/ReactAndroid/src/main/java/com/facebook/yoga/YogaNodeJNIBase.java +5 -12
- package/ReactAndroid/src/main/java/com/facebook/yoga/YogaNodeJNIFinalizer.java +1 -1
- package/ReactAndroid/src/main/jni/CMakeLists.txt +4 -6
- package/ReactAndroid/src/main/jni/first-party/fb/CMakeLists.txt +1 -1
- package/ReactAndroid/src/main/jni/first-party/fbgloginit/CMakeLists.txt +1 -1
- package/ReactAndroid/src/main/jni/first-party/yogajni/jni/YGJNIVanilla.cpp +16 -42
- package/ReactAndroid/src/main/jni/react/devsupport/CMakeLists.txt +19 -0
- package/ReactAndroid/src/main/jni/react/devsupport/JCxxInspectorPackagerConnection.cpp +55 -0
- package/ReactAndroid/src/main/jni/react/devsupport/JCxxInspectorPackagerConnection.h +62 -0
- package/ReactAndroid/src/main/jni/react/devsupport/JCxxInspectorPackagerConnectionDelegateImpl.cpp +72 -0
- package/ReactAndroid/src/main/jni/react/devsupport/JCxxInspectorPackagerConnectionDelegateImpl.h +69 -0
- package/ReactAndroid/src/main/jni/react/devsupport/JCxxInspectorPackagerConnectionWebSocket.cpp +45 -0
- package/ReactAndroid/src/main/jni/react/devsupport/JCxxInspectorPackagerConnectionWebSocket.h +56 -0
- package/ReactAndroid/src/main/jni/react/devsupport/JCxxInspectorPackagerConnectionWebSocketDelegate.cpp +53 -0
- package/ReactAndroid/src/main/jni/react/devsupport/JCxxInspectorPackagerConnectionWebSocketDelegate.h +49 -0
- package/ReactAndroid/src/main/jni/react/devsupport/JInspectorFlags.cpp +36 -0
- package/ReactAndroid/src/main/jni/react/devsupport/JInspectorFlags.h +32 -0
- package/ReactAndroid/src/main/jni/react/devsupport/JOptional.cpp +29 -0
- package/ReactAndroid/src/main/jni/react/devsupport/JOptional.h +27 -0
- package/ReactAndroid/src/main/jni/react/devsupport/OnLoad.cpp +22 -0
- package/ReactAndroid/src/main/jni/react/fabric/Binding.cpp +2 -25
- package/ReactAndroid/src/main/jni/react/fabric/Binding.h +0 -2
- package/ReactAndroid/src/main/jni/react/fabric/CMakeLists.txt +1 -1
- package/ReactAndroid/src/main/jni/react/fabric/CoreComponentsRegistry.cpp +8 -6
- package/ReactAndroid/src/main/jni/react/fabric/FabricMountingManager.cpp +4 -40
- package/ReactAndroid/src/main/jni/react/fabric/FabricMountingManager.h +0 -2
- package/ReactAndroid/src/main/jni/react/fabric/JEmptyReactNativeConfig.cpp +47 -0
- package/ReactAndroid/src/main/jni/react/fabric/JEmptyReactNativeConfig.h +38 -0
- package/ReactAndroid/src/main/jni/react/fabric/OnLoad.cpp +2 -0
- package/ReactAndroid/src/main/jni/react/fabric/ReactNativeConfigHolder.cpp +1 -1
- package/ReactAndroid/src/main/jni/react/fabric/ReactNativeConfigHolder.h +1 -1
- package/ReactAndroid/src/main/jni/react/featureflags/CMakeLists.txt +34 -0
- package/ReactAndroid/src/main/jni/react/featureflags/JReactNativeFeatureFlagsCxxInterop.cpp +206 -0
- package/ReactAndroid/src/main/jni/react/featureflags/JReactNativeFeatureFlagsCxxInterop.h +73 -0
- package/ReactAndroid/src/main/jni/react/featureflags/OnLoad.cpp +16 -0
- package/ReactAndroid/src/main/jni/react/jni/CMakeLists.txt +1 -2
- package/ReactAndroid/src/main/jni/react/jni/CatalystInstanceImpl.cpp +18 -29
- package/ReactAndroid/src/main/jni/react/jni/CatalystInstanceImpl.h +3 -4
- package/ReactAndroid/src/main/jni/react/jni/CxxModuleWrapper.h +0 -10
- package/ReactAndroid/src/main/jni/react/jni/JCallback.h +0 -7
- package/ReactAndroid/src/main/jni/react/jni/JInspector.cpp +2 -5
- package/ReactAndroid/src/main/jni/react/jni/JInspector.h +0 -4
- package/ReactAndroid/src/main/jni/react/jni/JMessageQueueThread.cpp +3 -15
- package/ReactAndroid/src/main/jni/react/jni/JMessageQueueThread.h +0 -4
- package/ReactAndroid/src/main/jni/react/jni/MethodInvoker.cpp +3 -2
- package/ReactAndroid/src/main/jni/react/jni/OnLoad.cpp +18 -19
- package/ReactAndroid/src/main/jni/react/jni/ProxyExecutor.cpp +0 -3
- package/ReactAndroid/src/main/jni/react/jni/ProxyExecutor.h +0 -1
- package/ReactAndroid/src/main/jni/react/jni/ReadableNativeArray.cpp +2 -2
- package/ReactAndroid/src/main/jni/react/jni/ReadableNativeMap.cpp +2 -2
- package/ReactAndroid/src/main/jni/react/newarchdefaults/CMakeLists.txt +2 -0
- package/ReactAndroid/src/main/jni/react/newarchdefaults/DefaultComponentsRegistry.cpp +15 -7
- package/ReactAndroid/src/main/jni/react/newarchdefaults/DefaultTurboModuleManagerDelegate.cpp +31 -2
- package/ReactAndroid/src/main/jni/react/newarchdefaults/DefaultTurboModuleManagerDelegate.h +11 -1
- package/ReactAndroid/src/main/jni/react/reactnativeblob/BlobCollector.cpp +1 -1
- package/ReactAndroid/src/main/jni/react/reactnativeblob/BlobCollector.h +2 -4
- package/ReactAndroid/src/main/jni/react/runtime/cxxreactpackage/CMakeLists.txt +29 -0
- package/ReactAndroid/src/main/jni/react/runtime/cxxreactpackage/ReactCommon/CxxReactPackage.h +31 -0
- package/{ReactCommon/hermes/executor/JSITracing.cpp → ReactAndroid/src/main/jni/react/runtime/cxxreactpackage/ReactCommon/OnLoad.cpp} +5 -7
- package/ReactAndroid/src/main/jni/react/runtime/hermes/jni/JHermesInstance.cpp +11 -5
- package/ReactAndroid/src/main/jni/react/runtime/hermes/jni/JHermesInstance.h +13 -6
- package/ReactAndroid/src/main/jni/react/runtime/jni/CMakeLists.txt +1 -0
- package/ReactAndroid/src/main/jni/react/runtime/jni/{JJSEngineInstance.h → JJSRuntimeFactory.h} +4 -4
- package/ReactAndroid/src/main/jni/react/runtime/jni/JReactInstance.cpp +10 -4
- package/ReactAndroid/src/main/jni/react/runtime/jni/JReactInstance.h +6 -4
- package/ReactAndroid/src/main/jni/react/runtime/jsc/jni/OnLoad.cpp +5 -5
- package/ReactAndroid/src/main/jni/react/turbomodule/ReactCommon/OnLoad.cpp +1 -1
- package/ReactAndroid/src/main/jni/react/turbomodule/ReactCommon/TurboModuleManager.cpp +28 -10
- package/ReactAndroid/src/main/jni/react/turbomodule/ReactCommon/TurboModuleManager.h +6 -3
- package/ReactAndroid/src/main/jni/react/turbomodule/ReactCommon/TurboModuleManagerDelegate.h +1 -1
- package/ReactAndroid/src/main/jni/react/uimanager/UIConstantsProviderManager.cpp +44 -13
- package/ReactAndroid/src/main/jni/react/uimanager/UIConstantsProviderManager.h +72 -6
- package/ReactAndroid/src/main/jni/third-party/fmt/CMakeLists.txt +1 -1
- package/ReactAndroid/src/main/jni/third-party/folly/CMakeLists.txt +21 -72
- package/ReactAndroid/src/main/res/devsupport/drawable/redbox_top_border_background.xml +2 -1
- package/ReactAndroid/src/main/res/devsupport/values/strings.xml +6 -7
- package/ReactAndroid/src/main/res/devsupport/values-af/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-ar/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-bg/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-bn/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-cs/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-da/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-el/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-en-rGB/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-es/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-es-rES/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-et/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-fa/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-fi/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-fr/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-fr-rCA/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-gu/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-hi/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-hr/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-hu/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-it/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-iw/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-ja/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-ka/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-km/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-kn/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-ko/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-lt/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-lv/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-mk/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-ml/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-mr/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-ms/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-my/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-nl/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-pa/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-pl/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-pt/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-pt-rPT/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-ro/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-ru/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-si/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-sk/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-sl/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-sq/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-sr/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-sv/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-sw/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-ta/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-te/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-th/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-tr/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-uk/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-ur/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-vi/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-zh-rCN/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-zh-rHK/strings.xml +0 -2
- package/ReactAndroid/src/main/res/devsupport/values-zh-rTW/strings.xml +0 -2
- package/ReactAndroid/src/main/res/shell/values/styles.xml +2 -1
- package/ReactAndroid/src/main/res/views/uimanager/values-be/strings.xml +3 -0
- package/ReactAndroid/src/main/res/views/uimanager/values-kk/strings.xml +1 -0
- package/ReactAndroid/src/main/res/views/uimanager/values-ky/strings.xml +1 -0
- package/ReactAndroid/src/main/res/views/uimanager/values-mn/strings.xml +1 -0
- package/ReactApple/Libraries/RCTFoundation/RCTDeprecation/Exported/RCTDeprecation.h +16 -0
- package/ReactApple/Libraries/RCTFoundation/RCTDeprecation/RCTDeprecation.m +8 -0
- package/ReactApple/Libraries/RCTFoundation/RCTDeprecation/RCTDeprecation.podspec +25 -0
- package/ReactApple/Libraries/RCTFoundation/RCTDeprecation/README.md +1 -0
- package/ReactApple/Libraries/RCTFoundation/README.md +12 -0
- package/ReactApple/README.md +5 -0
- package/ReactCommon/.clang-tidy +7 -0
- package/ReactCommon/React-Fabric.podspec +24 -7
- package/ReactCommon/React-FabricImage.podspec +6 -4
- package/ReactCommon/React-rncore.podspec +0 -9
- package/ReactCommon/ReactCommon.podspec +9 -4
- package/ReactCommon/butter/CMakeLists.txt +1 -2
- package/ReactCommon/callinvoker/CMakeLists.txt +1 -2
- package/ReactCommon/callinvoker/React-callinvoker.podspec +4 -2
- package/ReactCommon/callinvoker/ReactCommon/CallInvoker.h +7 -3
- package/ReactCommon/cxxreact/Instance.cpp +44 -21
- package/ReactCommon/cxxreact/Instance.h +17 -5
- package/ReactCommon/cxxreact/JSBigString.cpp +2 -2
- package/ReactCommon/cxxreact/JSExecutor.cpp +13 -0
- package/ReactCommon/cxxreact/JSExecutor.h +18 -6
- package/ReactCommon/cxxreact/MoveWrapper.h +125 -0
- package/ReactCommon/cxxreact/NativeToJsBridge.cpp +12 -7
- package/ReactCommon/cxxreact/NativeToJsBridge.h +4 -1
- package/ReactCommon/cxxreact/React-cxxreact.podspec +5 -4
- package/ReactCommon/cxxreact/ReactMarker.cpp +15 -2
- package/ReactCommon/cxxreact/ReactMarker.h +1 -0
- package/ReactCommon/cxxreact/ReactNativeVersion.h +4 -4
- package/ReactCommon/cxxreact/tests/jsbigstring.cpp +0 -1
- package/ReactCommon/hermes/React-hermes.podspec +7 -8
- package/ReactCommon/hermes/executor/HermesExecutorFactory.cpp +49 -7
- package/ReactCommon/hermes/executor/HermesExecutorFactory.h +14 -2
- package/ReactCommon/hermes/inspector-modern/CMakeLists.txt +3 -6
- package/ReactCommon/hermes/inspector-modern/chrome/ConnectionDemux.cpp +3 -3
- package/ReactCommon/hermes/inspector-modern/chrome/ConnectionDemux.h +5 -5
- package/ReactCommon/hermes/inspector-modern/chrome/HermesRuntimeAgentDelegate.cpp +228 -0
- package/ReactCommon/hermes/inspector-modern/chrome/HermesRuntimeAgentDelegate.h +71 -0
- package/ReactCommon/hermes/inspector-modern/chrome/Registration.cpp +2 -2
- package/ReactCommon/hermes/inspector-modern/chrome/Registration.h +1 -1
- package/ReactCommon/hermes/inspector-modern/chrome/tests/ConnectionDemuxTests.cpp +5 -5
- package/ReactCommon/jsc/CMakeLists.txt +0 -4
- package/ReactCommon/jsc/JSCRuntime.cpp +107 -56
- package/ReactCommon/jsc/React-jsc.podspec +1 -1
- package/ReactCommon/jserrorhandler/CMakeLists.txt +1 -1
- package/ReactCommon/jserrorhandler/React-jserrorhandler.podspec +4 -3
- package/ReactCommon/jsi/React-jsi.podspec +4 -3
- package/ReactCommon/jsi/jsi/JSIDynamic.cpp +9 -2
- package/ReactCommon/jsi/jsi/JSIDynamic.h +2 -1
- package/ReactCommon/jsi/jsi/decorator.h +4 -0
- package/ReactCommon/jsi/jsi/jsi-inl.h +5 -0
- package/ReactCommon/jsi/jsi/jsi.h +15 -0
- package/ReactCommon/jsi/jsi/test/testlib.cpp +94 -2
- package/ReactCommon/jsiexecutor/React-jsiexecutor.podspec +5 -3
- package/ReactCommon/jsiexecutor/jsireact/JSIExecutor.cpp +0 -30
- package/ReactCommon/jsinspector-modern/CMakeLists.txt +10 -0
- package/ReactCommon/jsinspector-modern/CONCEPTS.md +27 -0
- package/ReactCommon/jsinspector-modern/ExecutionContext.cpp +66 -0
- package/ReactCommon/jsinspector-modern/ExecutionContext.h +109 -0
- package/ReactCommon/jsinspector-modern/ExecutionContextManager.cpp +19 -0
- package/ReactCommon/jsinspector-modern/ExecutionContextManager.h +25 -0
- package/ReactCommon/jsinspector-modern/FallbackRuntimeAgentDelegate.cpp +70 -0
- package/ReactCommon/jsinspector-modern/FallbackRuntimeAgentDelegate.h +66 -0
- package/ReactCommon/jsinspector-modern/InspectorFlags.cpp +58 -0
- package/ReactCommon/jsinspector-modern/InspectorFlags.h +46 -0
- package/ReactCommon/jsinspector-modern/InspectorInterfaces.cpp +94 -17
- package/ReactCommon/jsinspector-modern/InspectorInterfaces.h +62 -7
- package/ReactCommon/jsinspector-modern/InspectorPackagerConnection.cpp +365 -0
- package/ReactCommon/jsinspector-modern/InspectorPackagerConnection.h +85 -0
- package/ReactCommon/jsinspector-modern/InspectorPackagerConnectionImpl.h +127 -0
- package/ReactCommon/jsinspector-modern/InspectorUtilities.cpp +39 -0
- package/ReactCommon/jsinspector-modern/InspectorUtilities.h +52 -0
- package/ReactCommon/jsinspector-modern/InstanceAgent.cpp +75 -0
- package/ReactCommon/jsinspector-modern/InstanceAgent.h +66 -0
- package/ReactCommon/jsinspector-modern/InstanceTarget.cpp +82 -0
- package/ReactCommon/jsinspector-modern/InstanceTarget.h +97 -0
- package/ReactCommon/jsinspector-modern/PageAgent.cpp +153 -0
- package/ReactCommon/jsinspector-modern/PageAgent.h +89 -0
- package/ReactCommon/jsinspector-modern/PageTarget.cpp +166 -0
- package/ReactCommon/jsinspector-modern/PageTarget.h +190 -0
- package/ReactCommon/jsinspector-modern/Parsing.cpp +32 -0
- package/ReactCommon/jsinspector-modern/Parsing.h +69 -0
- package/ReactCommon/jsinspector-modern/React-jsinspector.podspec +31 -2
- package/ReactCommon/jsinspector-modern/ReactCdp.h +16 -0
- package/ReactCommon/jsinspector-modern/RuntimeAgent.cpp +138 -0
- package/ReactCommon/jsinspector-modern/RuntimeAgent.h +93 -0
- package/ReactCommon/jsinspector-modern/RuntimeAgentDelegate.h +51 -0
- package/ReactCommon/jsinspector-modern/RuntimeTarget.cpp +109 -0
- package/ReactCommon/jsinspector-modern/RuntimeTarget.h +162 -0
- package/ReactCommon/jsinspector-modern/ScopedExecutor.h +97 -0
- package/ReactCommon/jsinspector-modern/SessionState.h +51 -0
- package/ReactCommon/jsinspector-modern/UniqueMonostate.h +54 -0
- package/ReactCommon/jsinspector-modern/WeakList.h +79 -0
- package/ReactCommon/jsinspector-modern/WebSocketInterfaces.h +62 -0
- package/ReactCommon/jsinspector-modern/tests/FollyDynamicMatchers.cpp +50 -0
- package/ReactCommon/jsinspector-modern/tests/FollyDynamicMatchers.h +80 -0
- package/ReactCommon/jsinspector-modern/tests/InspectorMocks.h +163 -0
- package/ReactCommon/jsinspector-modern/tests/InspectorPackagerConnectionTest.cpp +1343 -0
- package/ReactCommon/jsinspector-modern/tests/JsiIntegrationTest.cpp +576 -0
- package/ReactCommon/jsinspector-modern/tests/PageTargetTest.cpp +517 -0
- package/ReactCommon/jsinspector-modern/tests/UniquePtrFactory.h +110 -0
- package/ReactCommon/jsinspector-modern/tests/UniquePtrFactoryTest.cpp +84 -0
- package/ReactCommon/jsinspector-modern/tests/WeakListTest.cpp +91 -0
- package/ReactCommon/jsinspector-modern/tests/engines/JsiIntegrationTestGenericEngineAdapter.cpp +48 -0
- package/ReactCommon/jsinspector-modern/tests/engines/JsiIntegrationTestGenericEngineAdapter.h +44 -0
- package/ReactCommon/jsinspector-modern/tests/engines/JsiIntegrationTestHermesEngineAdapter.cpp +58 -0
- package/ReactCommon/jsinspector-modern/tests/engines/JsiIntegrationTestHermesEngineAdapter.h +44 -0
- package/ReactCommon/logger/CMakeLists.txt +1 -1
- package/ReactCommon/logger/React-logger.podspec +3 -3
- package/ReactCommon/react/bridging/Array.h +26 -2
- package/ReactCommon/react/bridging/CMakeLists.txt +0 -1
- package/ReactCommon/react/bridging/CallbackWrapper.h +8 -5
- package/ReactCommon/react/bridging/Function.h +63 -24
- package/ReactCommon/react/bridging/LongLivedObject.h +8 -6
- package/ReactCommon/react/bridging/tests/BridgingTest.cpp +51 -1
- package/ReactCommon/react/bridging/tests/BridgingTest.h +1 -1
- package/ReactCommon/react/config/CMakeLists.txt +1 -2
- package/ReactCommon/react/config/ReactNativeConfig.cpp +3 -10
- package/ReactCommon/react/config/ReactNativeConfig.h +4 -4
- package/ReactCommon/react/debug/CMakeLists.txt +0 -1
- package/ReactCommon/react/featureflags/CMakeLists.txt +20 -0
- package/ReactCommon/react/featureflags/React-featureflags.podspec +44 -0
- package/ReactCommon/react/featureflags/ReactNativeFeatureFlags.cpp +82 -0
- package/ReactCommon/react/featureflags/ReactNativeFeatureFlags.h +126 -0
- package/ReactCommon/react/featureflags/ReactNativeFeatureFlagsAccessor.cpp +251 -0
- package/ReactCommon/react/featureflags/ReactNativeFeatureFlagsAccessor.h +68 -0
- package/ReactCommon/react/featureflags/ReactNativeFeatureFlagsDefaults.h +71 -0
- package/ReactCommon/react/featureflags/ReactNativeFeatureFlagsProvider.h +40 -0
- package/ReactCommon/react/featureflags/tests/ReactNativeFeatureFlagsTest.cpp +124 -0
- package/ReactCommon/react/nativemodule/core/CMakeLists.txt +1 -1
- package/ReactCommon/react/nativemodule/core/ReactCommon/CxxTurboModuleUtils.cpp +32 -0
- package/ReactCommon/react/nativemodule/core/ReactCommon/CxxTurboModuleUtils.h +67 -0
- package/ReactCommon/react/nativemodule/core/ReactCommon/TurboModule.cpp +25 -0
- package/ReactCommon/react/nativemodule/core/ReactCommon/TurboModule.h +7 -0
- package/ReactCommon/react/nativemodule/core/ReactCommon/TurboModuleBinding.cpp +28 -52
- package/ReactCommon/react/nativemodule/core/ReactCommon/TurboModuleBinding.h +9 -2
- package/ReactCommon/react/nativemodule/core/ReactCommon/TurboModuleUtils.h +1 -0
- package/ReactCommon/react/nativemodule/core/platform/android/ReactCommon/JavaTurboModule.cpp +207 -157
- package/ReactCommon/react/nativemodule/core/platform/android/ReactCommon/JavaTurboModule.h +2 -2
- package/ReactCommon/react/nativemodule/core/platform/ios/React-NativeModulesApple.podspec +5 -2
- package/ReactCommon/react/nativemodule/core/platform/ios/ReactCommon/RCTInteropTurboModule.h +1 -1
- package/ReactCommon/react/nativemodule/core/platform/ios/ReactCommon/RCTInteropTurboModule.mm +4 -4
- package/ReactCommon/react/nativemodule/core/platform/ios/ReactCommon/RCTRuntimeExecutor.h +30 -0
- package/ReactCommon/react/nativemodule/core/platform/ios/ReactCommon/RCTRuntimeExecutor.mm +34 -0
- package/ReactCommon/react/nativemodule/core/platform/ios/ReactCommon/RCTTurboModule.h +12 -3
- package/ReactCommon/react/nativemodule/core/platform/ios/ReactCommon/RCTTurboModule.mm +227 -199
- package/ReactCommon/react/nativemodule/core/platform/ios/ReactCommon/RCTTurboModuleManager.h +11 -0
- package/ReactCommon/react/nativemodule/core/platform/ios/ReactCommon/RCTTurboModuleManager.mm +38 -18
- package/ReactCommon/react/nativemodule/featureflags/NativeReactNativeFeatureFlags.cpp +88 -0
- package/ReactCommon/react/nativemodule/featureflags/NativeReactNativeFeatureFlags.h +54 -0
- package/ReactCommon/react/nativemodule/samples/ReactCommon-Samples.podspec +5 -3
- package/ReactCommon/react/nativemodule/samples/platform/android/CMakeLists.txt +0 -1
- package/ReactCommon/react/nativemodule/samples/platform/android/SampleTurboModule.java +2 -1
- package/ReactCommon/react/renderer/animations/CMakeLists.txt +1 -2
- package/ReactCommon/react/renderer/animations/LayoutAnimationKeyFrameManager.cpp +0 -39
- package/ReactCommon/react/renderer/animations/LayoutAnimationKeyFrameManager.h +0 -3
- package/ReactCommon/react/renderer/animations/tests/LayoutAnimationTest.cpp +2 -0
- package/ReactCommon/react/renderer/attributedstring/CMakeLists.txt +1 -2
- package/ReactCommon/react/renderer/attributedstring/TextAttributes.cpp +9 -0
- package/ReactCommon/react/renderer/attributedstring/TextAttributes.h +4 -3
- package/ReactCommon/react/renderer/attributedstring/conversions.h +44 -37
- package/ReactCommon/react/renderer/attributedstring/primitives.h +0 -86
- package/ReactCommon/react/renderer/componentregistry/CMakeLists.txt +2 -1
- package/ReactCommon/react/renderer/componentregistry/ComponentDescriptorRegistry.cpp +16 -30
- package/ReactCommon/react/renderer/componentregistry/ComponentDescriptorRegistry.h +0 -7
- package/ReactCommon/react/renderer/componentregistry/native/CMakeLists.txt +1 -2
- package/ReactCommon/react/renderer/components/image/CMakeLists.txt +0 -1
- package/ReactCommon/react/renderer/components/legacyviewmanagerinterop/CMakeLists.txt +0 -1
- package/ReactCommon/react/renderer/components/legacyviewmanagerinterop/RCTLegacyViewManagerInteropCoordinator.h +1 -6
- package/ReactCommon/react/renderer/components/legacyviewmanagerinterop/RCTLegacyViewManagerInteropCoordinator.mm +6 -34
- package/ReactCommon/react/renderer/components/legacyviewmanagerinterop/UnstableLegacyViewManagerAutomaticComponentDescriptor.cpp +26 -0
- package/ReactCommon/react/renderer/components/legacyviewmanagerinterop/UnstableLegacyViewManagerAutomaticComponentDescriptor.h +35 -0
- package/{ReactAndroid/src/main/jni/react/jni/OnLoad.h → ReactCommon/react/renderer/components/legacyviewmanagerinterop/UnstableLegacyViewManagerAutomaticShadowNode.cpp} +2 -5
- package/ReactCommon/react/renderer/components/legacyviewmanagerinterop/UnstableLegacyViewManagerAutomaticShadowNode.h +22 -0
- package/ReactCommon/react/renderer/components/modal/CMakeLists.txt +0 -1
- package/ReactCommon/react/renderer/components/progressbar/CMakeLists.txt +0 -1
- package/ReactCommon/react/renderer/components/root/CMakeLists.txt +1 -2
- package/ReactCommon/react/renderer/components/scrollview/CMakeLists.txt +1 -2
- package/ReactCommon/react/renderer/components/scrollview/ScrollViewEventEmitter.cpp +8 -0
- package/ReactCommon/react/renderer/components/scrollview/ScrollViewEventEmitter.h +1 -0
- package/ReactCommon/react/renderer/components/scrollview/ScrollViewProps.cpp +18 -0
- package/ReactCommon/react/renderer/components/scrollview/ScrollViewProps.h +2 -0
- package/ReactCommon/react/renderer/components/switch/CMakeLists.txt +0 -1
- package/ReactCommon/react/renderer/components/text/BaseTextProps.cpp +8 -0
- package/ReactCommon/react/renderer/components/text/BaseTextShadowNode.cpp +2 -3
- package/ReactCommon/react/renderer/components/text/CMakeLists.txt +1 -2
- package/ReactCommon/react/renderer/components/text/ParagraphLayoutManager.cpp +5 -2
- package/ReactCommon/react/renderer/components/text/ParagraphLayoutManager.h +3 -1
- package/ReactCommon/react/renderer/components/text/ParagraphShadowNode.cpp +25 -14
- package/ReactCommon/react/renderer/components/text/ParagraphShadowNode.h +0 -1
- package/ReactCommon/react/renderer/components/text/RawTextShadowNode.h +0 -8
- package/ReactCommon/react/renderer/components/text/TextShadowNode.h +0 -7
- package/ReactCommon/react/renderer/components/textinput/CMakeLists.txt +3 -4
- package/ReactCommon/react/renderer/components/textinput/{androidtextinput → platform/android}/react/renderer/components/androidtextinput/AndroidTextInputComponentDescriptor.h +22 -28
- package/ReactCommon/react/renderer/components/textinput/{androidtextinput → platform/android}/react/renderer/components/androidtextinput/AndroidTextInputProps.cpp +18 -28
- package/ReactCommon/react/renderer/components/textinput/{androidtextinput → platform/android}/react/renderer/components/androidtextinput/AndroidTextInputProps.h +1 -2
- package/ReactCommon/react/renderer/components/textinput/{androidtextinput → platform/android}/react/renderer/components/androidtextinput/AndroidTextInputShadowNode.cpp +5 -1
- package/ReactCommon/react/renderer/components/textinput/{androidtextinput → platform/android}/react/renderer/components/androidtextinput/AndroidTextInputShadowNode.h +0 -1
- package/ReactCommon/react/renderer/components/textinput/{androidtextinput → platform/android}/react/renderer/components/androidtextinput/AndroidTextInputState.cpp +4 -7
- package/ReactCommon/react/renderer/components/textinput/{androidtextinput → platform/android}/react/renderer/components/androidtextinput/AndroidTextInputState.h +2 -5
- package/ReactCommon/react/renderer/components/textinput/{iostextinput → platform/ios}/react/renderer/components/iostextinput/TextInputProps.cpp +6 -0
- package/ReactCommon/react/renderer/components/textinput/{iostextinput → platform/ios}/react/renderer/components/iostextinput/TextInputProps.h +1 -0
- package/ReactCommon/react/renderer/components/textinput/{iostextinput → platform/ios}/react/renderer/components/iostextinput/TextInputShadowNode.cpp +9 -2
- package/ReactCommon/react/renderer/components/textinput/{iostextinput → platform/ios}/react/renderer/components/iostextinput/TextInputShadowNode.h +0 -1
- package/ReactCommon/react/renderer/components/textinput/platform/ios/react/renderer/components/iostextinput/TextInputState.cpp +10 -0
- package/ReactCommon/react/renderer/components/textinput/{iostextinput → platform/ios}/react/renderer/components/iostextinput/TextInputState.h +0 -16
- package/ReactCommon/react/renderer/components/unimplementedview/CMakeLists.txt +1 -2
- package/ReactCommon/react/renderer/components/unimplementedview/UnimplementedViewComponentDescriptor.cpp +4 -4
- package/ReactCommon/react/renderer/components/unimplementedview/UnimplementedViewComponentDescriptor.h +1 -1
- package/ReactCommon/react/renderer/components/view/AccessibilityPrimitives.h +1 -17
- package/ReactCommon/react/renderer/components/view/AccessibilityProps.h +1 -6
- package/ReactCommon/react/renderer/components/view/BaseViewEventEmitter.cpp +31 -37
- package/ReactCommon/react/renderer/components/view/BaseViewProps.cpp +48 -21
- package/ReactCommon/react/renderer/components/view/BaseViewProps.h +2 -0
- package/ReactCommon/react/renderer/components/view/CMakeLists.txt +0 -1
- package/ReactCommon/react/renderer/components/view/ViewShadowNode.cpp +11 -3
- package/ReactCommon/react/renderer/components/view/ViewShadowNode.h +0 -6
- package/ReactCommon/react/renderer/components/view/YogaLayoutableShadowNode.cpp +182 -198
- package/ReactCommon/react/renderer/components/view/YogaLayoutableShadowNode.h +4 -9
- package/ReactCommon/react/renderer/components/view/YogaStylableProps.cpp +686 -309
- package/ReactCommon/react/renderer/components/view/YogaStylableProps.h +16 -26
- package/ReactCommon/react/renderer/components/view/conversions.h +79 -144
- package/ReactCommon/react/renderer/components/view/platform/android/react/renderer/components/view/HostPlatformViewProps.h +0 -3
- package/ReactCommon/react/renderer/components/view/primitives.h +2 -0
- package/ReactCommon/react/renderer/components/view/propsConversions.h +0 -319
- package/ReactCommon/react/renderer/components/view/tests/LayoutTest.cpp +26 -26
- package/ReactCommon/react/renderer/components/view/tests/ViewTest.cpp +4 -4
- package/ReactCommon/react/renderer/core/CMakeLists.txt +2 -2
- package/ReactCommon/react/renderer/core/ComponentDescriptor.h +2 -10
- package/ReactCommon/react/renderer/core/ConcreteComponentDescriptor.h +11 -13
- package/ReactCommon/react/renderer/core/ConcreteShadowNode.h +3 -2
- package/ReactCommon/react/renderer/core/ConcreteState.h +1 -6
- package/ReactCommon/react/renderer/core/EventEmitter.h +0 -7
- package/ReactCommon/react/renderer/core/EventLogger.h +2 -2
- package/ReactCommon/react/renderer/core/EventQueueProcessor.cpp +4 -11
- package/ReactCommon/react/renderer/core/LayoutMetrics.h +4 -21
- package/ReactCommon/react/renderer/core/LayoutPrimitives.h +6 -17
- package/ReactCommon/react/renderer/core/LayoutableShadowNode.cpp +8 -19
- package/ReactCommon/react/renderer/core/LayoutableShadowNode.h +0 -3
- package/ReactCommon/react/renderer/core/Props.cpp +0 -23
- package/ReactCommon/react/renderer/core/Props.h +3 -4
- package/ReactCommon/react/renderer/core/PropsMacros.h +4 -2
- package/ReactCommon/react/renderer/core/PropsParserContext.h +0 -6
- package/ReactCommon/react/renderer/core/RawProps.cpp +121 -5
- package/ReactCommon/react/renderer/core/RawProps.h +30 -14
- package/ReactCommon/react/renderer/core/RawPropsParser.cpp +7 -8
- package/ReactCommon/react/renderer/core/RawPropsParser.h +1 -1
- package/ReactCommon/react/renderer/core/RawPropsPrimitives.h +0 -1
- package/ReactCommon/react/renderer/core/ShadowNode.cpp +1 -1
- package/ReactCommon/react/renderer/core/ShadowNodeFamily.cpp +2 -2
- package/ReactCommon/react/renderer/core/ShadowNodeFamily.h +2 -4
- package/ReactCommon/react/renderer/core/ShadowNodeTraits.h +10 -31
- package/ReactCommon/react/renderer/core/graphicsConversions.h +2 -23
- package/ReactCommon/react/renderer/core/propsConversions.h +2 -4
- package/ReactCommon/react/renderer/core/tests/ComponentDescriptorTest.cpp +9 -6
- package/ReactCommon/react/renderer/core/tests/EventTargetTests.cpp +43 -0
- package/ReactCommon/react/renderer/core/tests/FindNodeAtPointTest.cpp +1 -1
- package/ReactCommon/react/renderer/core/tests/RawPropsTest.cpp +155 -26
- package/ReactCommon/react/renderer/core/tests/ShadowNodeTest.cpp +40 -64
- package/ReactCommon/react/renderer/css/CSSDeclaredStyle.h +108 -0
- package/ReactCommon/react/renderer/css/CSSKeywords.h +458 -0
- package/ReactCommon/react/renderer/css/CSSLengthUnit.h +165 -0
- package/ReactCommon/react/renderer/css/CSSParser.h +220 -0
- package/ReactCommon/react/renderer/css/CSSProperties.h +1087 -0
- package/ReactCommon/react/renderer/css/CSSTokenizer.h +263 -0
- package/ReactCommon/react/renderer/css/CSSValue.h +277 -0
- package/ReactCommon/react/renderer/css/tests/CSSDeclaredStyleTest.cpp +151 -0
- package/ReactCommon/react/renderer/css/tests/CSSParserTest.cpp +317 -0
- package/ReactCommon/react/renderer/css/tests/CSSTokenizerTest.cpp +154 -0
- package/ReactCommon/react/renderer/debug/CMakeLists.txt +0 -1
- package/ReactCommon/react/renderer/debug/React-rendererdebug.podspec +4 -3
- package/ReactCommon/react/renderer/debug/flags.h +0 -4
- package/ReactCommon/react/renderer/element/CMakeLists.txt +0 -1
- package/ReactCommon/react/renderer/graphics/CMakeLists.txt +0 -1
- package/ReactCommon/react/renderer/graphics/Color.h +9 -7
- package/ReactCommon/react/renderer/graphics/React-graphics.podspec +10 -3
- package/ReactCommon/react/renderer/graphics/fromRawValueShared.h +50 -0
- package/ReactCommon/react/renderer/graphics/platform/android/react/renderer/graphics/PlatformColorParser.h +18 -7
- package/ReactCommon/react/renderer/graphics/platform/cxx/react/renderer/graphics/PlatformColorParser.h +16 -4
- package/ReactCommon/react/renderer/graphics/platform/ios/react/renderer/graphics/HostPlatformColor.h +55 -15
- package/ReactCommon/react/renderer/graphics/platform/ios/react/renderer/graphics/HostPlatformColor.mm +132 -0
- package/ReactCommon/react/renderer/graphics/platform/ios/react/renderer/graphics/PlatformColorParser.h +15 -17
- package/ReactCommon/react/renderer/graphics/platform/ios/react/renderer/graphics/PlatformColorParser.mm +73 -0
- package/ReactCommon/react/renderer/graphics/platform/ios/react/renderer/graphics/RCTPlatformColorUtils.h +8 -2
- package/ReactCommon/react/renderer/graphics/platform/ios/react/renderer/graphics/RCTPlatformColorUtils.mm +14 -3
- package/ReactCommon/react/renderer/imagemanager/CMakeLists.txt +0 -1
- package/ReactCommon/react/renderer/imagemanager/ImageManager.h +6 -4
- package/ReactCommon/react/renderer/imagemanager/platform/ios/React-ImageManager.podspec +1 -1
- package/ReactCommon/react/renderer/imagemanager/platform/ios/react/renderer/imagemanager/RCTImagePrimitivesConversions.h +4 -3
- package/ReactCommon/react/renderer/leakchecker/CMakeLists.txt +1 -2
- package/ReactCommon/react/renderer/mapbuffer/CMakeLists.txt +0 -1
- package/ReactCommon/react/renderer/mapbuffer/MapBufferBuilder.cpp +4 -4
- package/ReactCommon/react/renderer/mapbuffer/MapBufferBuilder.h +2 -0
- package/ReactCommon/react/renderer/mounting/CMakeLists.txt +1 -2
- package/ReactCommon/react/renderer/mounting/Differentiator.cpp +37 -27
- package/ReactCommon/react/renderer/mounting/Differentiator.h +1 -1
- package/ReactCommon/react/renderer/mounting/ShadowTree.cpp +4 -4
- package/ReactCommon/react/renderer/mounting/ShadowView.cpp +1 -2
- package/ReactCommon/react/renderer/mounting/stubs.cpp +2 -2
- package/ReactCommon/react/renderer/mounting/tests/OrderIndexTest.cpp +244 -0
- package/ReactCommon/react/renderer/mounting/tests/StackingContextTest.cpp +18 -16
- package/ReactCommon/react/renderer/observers/intersection/IntersectionObserver.cpp +1 -2
- package/ReactCommon/react/renderer/observers/intersection/IntersectionObserverManager.cpp +37 -21
- package/ReactCommon/react/renderer/observers/mutation/MutationObserver.cpp +3 -3
- package/ReactCommon/react/renderer/observers/mutation/MutationObserver.h +3 -3
- package/ReactCommon/react/renderer/observers/mutation/MutationObserverManager.cpp +2 -2
- package/ReactCommon/react/renderer/observers/mutation/MutationObserverManager.h +2 -2
- package/ReactCommon/react/renderer/runtimescheduler/CMakeLists.txt +3 -2
- package/ReactCommon/react/renderer/runtimescheduler/React-runtimescheduler.podspec +4 -2
- package/ReactCommon/react/renderer/runtimescheduler/RuntimeScheduler.cpp +37 -136
- package/ReactCommon/react/renderer/runtimescheduler/RuntimeScheduler.h +46 -60
- package/ReactCommon/react/renderer/runtimescheduler/RuntimeSchedulerCallInvoker.cpp +2 -2
- package/ReactCommon/react/renderer/runtimescheduler/RuntimeSchedulerCallInvoker.h +3 -2
- package/ReactCommon/react/renderer/runtimescheduler/RuntimeScheduler_Legacy.cpp +215 -0
- package/ReactCommon/react/renderer/runtimescheduler/RuntimeScheduler_Legacy.h +164 -0
- package/ReactCommon/react/renderer/runtimescheduler/RuntimeScheduler_Modern.cpp +342 -0
- package/ReactCommon/react/renderer/runtimescheduler/RuntimeScheduler_Modern.h +196 -0
- package/ReactCommon/react/renderer/runtimescheduler/SchedulerPriorityUtils.h +1 -1
- package/ReactCommon/react/renderer/runtimescheduler/Task.cpp +2 -2
- package/ReactCommon/react/renderer/runtimescheduler/Task.h +6 -4
- package/ReactCommon/react/renderer/runtimescheduler/primitives.h +4 -20
- package/ReactCommon/react/renderer/runtimescheduler/tests/RuntimeSchedulerTest.cpp +435 -26
- package/ReactCommon/react/renderer/scheduler/CMakeLists.txt +1 -3
- package/ReactCommon/react/renderer/scheduler/Scheduler.cpp +21 -79
- package/ReactCommon/react/renderer/scheduler/Scheduler.h +0 -4
- package/ReactCommon/react/renderer/telemetry/CMakeLists.txt +1 -2
- package/ReactCommon/react/renderer/textlayoutmanager/CMakeLists.txt +1 -2
- package/ReactCommon/react/renderer/textlayoutmanager/TextLayoutContext.h +40 -0
- package/ReactCommon/react/renderer/textlayoutmanager/TextMeasureCache.h +8 -11
- package/ReactCommon/react/renderer/textlayoutmanager/platform/android/react/renderer/textlayoutmanager/TextLayoutManager.cpp +19 -16
- package/ReactCommon/react/renderer/textlayoutmanager/platform/android/react/renderer/textlayoutmanager/TextLayoutManager.h +2 -0
- package/ReactCommon/react/renderer/textlayoutmanager/platform/cxx/TextLayoutManager.cpp +1 -0
- package/ReactCommon/react/renderer/textlayoutmanager/platform/cxx/TextLayoutManager.h +7 -3
- package/ReactCommon/react/renderer/textlayoutmanager/platform/ios/react/renderer/textlayoutmanager/RCTAttributedTextUtils.mm +51 -36
- package/ReactCommon/react/renderer/textlayoutmanager/platform/ios/react/renderer/textlayoutmanager/RCTTextLayoutManager.mm +1 -1
- package/ReactCommon/react/renderer/textlayoutmanager/platform/ios/react/renderer/textlayoutmanager/RCTTextPrimitivesConversions.h +4 -19
- package/ReactCommon/react/renderer/textlayoutmanager/platform/ios/react/renderer/textlayoutmanager/TextLayoutManager.h +2 -0
- package/ReactCommon/react/renderer/textlayoutmanager/platform/ios/react/renderer/textlayoutmanager/TextLayoutManager.mm +1 -0
- package/ReactCommon/react/renderer/uimanager/CMakeLists.txt +1 -2
- package/ReactCommon/react/renderer/uimanager/PointerEventsProcessor.cpp +191 -52
- package/ReactCommon/react/renderer/uimanager/PointerEventsProcessor.h +34 -6
- package/ReactCommon/react/renderer/uimanager/PointerHoverTracker.cpp +150 -0
- package/ReactCommon/react/renderer/uimanager/PointerHoverTracker.h +71 -0
- package/ReactCommon/react/renderer/uimanager/UIManager.cpp +67 -20
- package/ReactCommon/react/renderer/uimanager/UIManager.h +10 -7
- package/ReactCommon/react/renderer/uimanager/UIManagerAnimationDelegate.h +0 -8
- package/ReactCommon/react/renderer/uimanager/UIManagerBinding.cpp +115 -92
- package/ReactCommon/react/renderer/uimanager/UIManagerBinding.h +1 -1
- package/ReactCommon/react/renderer/uimanager/primitives.h +36 -56
- package/ReactCommon/react/renderer/uimanager/tests/PointerEventsProcessorTest.cpp +401 -0
- package/ReactCommon/react/runtime/BridgelessJSCallInvoker.cpp +2 -1
- package/ReactCommon/react/runtime/BridgelessJSCallInvoker.h +1 -1
- package/ReactCommon/react/runtime/BridgelessNativeMethodCallInvoker.cpp +1 -1
- package/ReactCommon/react/runtime/BridgelessNativeMethodCallInvoker.h +3 -2
- package/ReactCommon/react/runtime/CMakeLists.txt +5 -0
- package/ReactCommon/react/runtime/JSRuntimeFactory.cpp +33 -0
- package/ReactCommon/react/runtime/JSRuntimeFactory.h +58 -0
- package/ReactCommon/react/runtime/React-RuntimeCore.podspec +8 -3
- package/ReactCommon/react/runtime/React-RuntimeHermes.podspec +9 -4
- package/ReactCommon/react/runtime/ReactInstance.cpp +39 -72
- package/ReactCommon/react/runtime/ReactInstance.h +19 -4
- package/ReactCommon/react/runtime/TimerManager.cpp +2 -1
- package/ReactCommon/react/runtime/TimerManager.h +1 -1
- package/ReactCommon/react/runtime/hermes/CMakeLists.txt +3 -0
- package/ReactCommon/react/runtime/hermes/HermesInstance.cpp +62 -10
- package/ReactCommon/react/runtime/hermes/HermesInstance.h +2 -1
- package/ReactCommon/react/runtime/iostests/RCTHostTests.mm +3 -2
- package/ReactCommon/react/runtime/nativeviewconfig/LegacyUIManagerConstantsProviderBinding.cpp +34 -3
- package/ReactCommon/react/runtime/nativeviewconfig/LegacyUIManagerConstantsProviderBinding.h +8 -1
- package/ReactCommon/react/runtime/platform/ios/React-RuntimeApple.podspec +4 -2
- package/ReactCommon/react/runtime/platform/ios/ReactCommon/RCTHermesInstance.h +3 -3
- package/ReactCommon/react/runtime/platform/ios/ReactCommon/RCTHermesInstance.mm +1 -1
- package/ReactCommon/react/runtime/platform/ios/ReactCommon/RCTHost+Internal.h +0 -2
- package/ReactCommon/react/runtime/platform/ios/ReactCommon/RCTHost.h +18 -5
- package/ReactCommon/react/runtime/platform/ios/ReactCommon/RCTHost.mm +111 -17
- package/ReactCommon/react/runtime/platform/ios/ReactCommon/RCTInstance.h +6 -3
- package/ReactCommon/react/runtime/platform/ios/ReactCommon/RCTInstance.mm +81 -21
- package/ReactCommon/react/runtime/platform/ios/ReactCommon/RCTJscInstance.h +3 -3
- package/ReactCommon/react/runtime/platform/ios/ReactCommon/RCTJscInstance.mm +2 -3
- package/ReactCommon/react/runtime/platform/ios/ReactCommon/RCTLegacyUIManagerConstantsProvider.mm +1 -1
- package/ReactCommon/react/runtime/tests/cxx/ReactInstanceTest.cpp +3 -2
- package/ReactCommon/react/test_utils/ios/Shims/ShimRCTInstance.h +1 -1
- package/ReactCommon/react/test_utils/ios/Shims/ShimRCTInstance.mm +7 -3
- package/ReactCommon/react/utils/CMakeLists.txt +1 -1
- package/ReactCommon/react/utils/CoreFeatures.cpp +1 -7
- package/ReactCommon/react/utils/CoreFeatures.h +4 -26
- package/ReactCommon/react/utils/PackTraits.h +31 -0
- package/ReactCommon/react/utils/React-utils.podspec +10 -2
- package/ReactCommon/react/utils/fnv1a.h +41 -0
- package/ReactCommon/react/utils/hash_combine.h +8 -6
- package/ReactCommon/react/utils/jsi.cpp +39 -0
- package/ReactCommon/react/utils/jsi.h +31 -0
- package/ReactCommon/react/utils/tests/fnv1aTests.cpp +24 -0
- package/ReactCommon/react/{renderer/components/view/platform/android/react/renderer/components/view/YogaStylablePropsMapBuffer.h → utils/to_underlying.h} +8 -8
- package/ReactCommon/reactperflogger/CMakeLists.txt +1 -2
- package/ReactCommon/reactperflogger/React-perflogger.podspec +3 -2
- package/ReactCommon/runtimeexecutor/CMakeLists.txt +1 -2
- package/ReactCommon/runtimeexecutor/React-runtimeexecutor.podspec +3 -2
- package/ReactCommon/yoga/Yoga.podspec +4 -4
- package/ReactCommon/yoga/cmake/project-defaults.cmake +1 -1
- package/ReactCommon/yoga/yoga/YGConfig.cpp +92 -0
- package/ReactCommon/yoga/yoga/YGConfig.h +158 -0
- package/ReactCommon/yoga/yoga/YGEnums.cpp +6 -14
- package/ReactCommon/yoga/yoga/YGEnums.h +20 -25
- package/ReactCommon/yoga/yoga/YGMacros.h +4 -38
- package/ReactCommon/yoga/yoga/YGNode.cpp +366 -0
- package/ReactCommon/yoga/yoga/YGNode.h +304 -0
- package/ReactCommon/yoga/yoga/YGNodeLayout.cpp +92 -0
- package/ReactCommon/yoga/yoga/YGNodeLayout.h +35 -0
- package/ReactCommon/yoga/yoga/YGNodeStyle.cpp +385 -0
- package/ReactCommon/yoga/yoga/YGNodeStyle.h +123 -0
- package/ReactCommon/yoga/yoga/YGPixelGrid.cpp +22 -0
- package/ReactCommon/yoga/yoga/YGPixelGrid.h +29 -0
- package/ReactCommon/yoga/yoga/YGValue.cpp +8 -0
- package/ReactCommon/yoga/yoga/YGValue.h +33 -8
- package/ReactCommon/yoga/yoga/Yoga.h +8 -314
- package/ReactCommon/yoga/yoga/algorithm/AbsoluteLayout.cpp +598 -0
- package/ReactCommon/yoga/yoga/algorithm/AbsoluteLayout.h +40 -0
- package/ReactCommon/yoga/yoga/algorithm/Align.h +4 -4
- package/ReactCommon/yoga/yoga/algorithm/Baseline.cpp +9 -9
- package/ReactCommon/yoga/yoga/algorithm/BoundAxis.h +11 -12
- package/ReactCommon/yoga/yoga/algorithm/Cache.cpp +35 -35
- package/ReactCommon/yoga/yoga/algorithm/Cache.h +5 -5
- package/ReactCommon/yoga/yoga/algorithm/CalculateLayout.cpp +605 -986
- package/ReactCommon/yoga/yoga/algorithm/CalculateLayout.h +17 -0
- package/ReactCommon/yoga/yoga/algorithm/FlexDirection.h +41 -15
- package/ReactCommon/yoga/yoga/algorithm/FlexLine.cpp +13 -7
- package/ReactCommon/yoga/yoga/algorithm/PixelGrid.cpp +8 -8
- package/ReactCommon/yoga/yoga/algorithm/SizingMode.h +73 -0
- package/ReactCommon/yoga/yoga/algorithm/TrailingPosition.h +44 -0
- package/ReactCommon/yoga/yoga/config/Config.cpp +0 -8
- package/ReactCommon/yoga/yoga/config/Config.h +0 -4
- package/ReactCommon/yoga/yoga/debug/AssertFatal.cpp +3 -0
- package/ReactCommon/yoga/yoga/debug/AssertFatal.h +3 -2
- package/ReactCommon/yoga/yoga/enums/Align.h +6 -10
- package/ReactCommon/yoga/yoga/enums/Dimension.h +4 -9
- package/ReactCommon/yoga/yoga/enums/Direction.h +4 -9
- package/ReactCommon/yoga/yoga/enums/Display.h +4 -9
- package/ReactCommon/yoga/yoga/enums/Edge.h +4 -9
- package/ReactCommon/yoga/yoga/enums/Errata.h +4 -12
- package/ReactCommon/yoga/yoga/enums/ExperimentalFeature.h +4 -10
- package/ReactCommon/yoga/yoga/enums/FlexDirection.h +4 -9
- package/ReactCommon/yoga/yoga/enums/Gutter.h +4 -9
- package/ReactCommon/yoga/yoga/enums/Justify.h +4 -9
- package/ReactCommon/yoga/yoga/enums/LogLevel.h +4 -9
- package/ReactCommon/yoga/yoga/enums/MeasureMode.h +4 -9
- package/ReactCommon/yoga/yoga/enums/NodeType.h +4 -9
- package/ReactCommon/yoga/yoga/enums/Overflow.h +4 -9
- package/ReactCommon/yoga/yoga/enums/PhysicalEdge.h +21 -0
- package/ReactCommon/yoga/yoga/enums/PositionType.h +4 -9
- package/ReactCommon/yoga/yoga/enums/Unit.h +4 -9
- package/ReactCommon/yoga/yoga/enums/Wrap.h +4 -9
- package/ReactCommon/yoga/yoga/enums/YogaEnums.h +69 -2
- package/ReactCommon/yoga/yoga/module.modulemap +21 -0
- package/ReactCommon/yoga/yoga/node/CachedMeasurement.h +5 -5
- package/ReactCommon/yoga/yoga/node/LayoutResults.cpp +4 -4
- package/ReactCommon/yoga/yoga/node/LayoutResults.h +55 -22
- package/ReactCommon/yoga/yoga/node/Node.cpp +74 -318
- package/ReactCommon/yoga/yoga/node/Node.h +64 -113
- package/ReactCommon/yoga/yoga/numeric/Comparison.h +33 -43
- package/ReactCommon/yoga/yoga/numeric/FloatOptional.h +30 -14
- package/ReactCommon/yoga/yoga/style/SmallValueBuffer.h +133 -0
- package/ReactCommon/yoga/yoga/style/Style.h +552 -207
- package/ReactCommon/yoga/yoga/style/StyleLength.h +139 -0
- package/ReactCommon/yoga/yoga/style/StyleValueHandle.h +98 -0
- package/ReactCommon/yoga/yoga/style/StyleValuePool.h +127 -0
- package/cli.js +17 -5
- package/flow/jest.js +1 -1
- package/flow/react.js +15 -0
- package/gradle/libs.versions.toml +12 -11
- package/index.js +61 -101
- package/jest/assetFileTransformer.js +1 -1
- package/jest/local-setup.js +0 -5
- package/jest/mockModal.js +2 -1
- package/jest/mockScrollView.js +1 -2
- package/jest/renderer.js +1 -1
- package/jest/setup.js +6 -3
- package/package.json +30 -17
- package/react-native.config.js +29 -1
- package/scripts/cocoapods/codegen.rb +15 -64
- package/scripts/cocoapods/codegen_utils.rb +13 -27
- package/scripts/cocoapods/helpers.rb +11 -0
- package/scripts/cocoapods/jsengine.rb +0 -1
- package/scripts/cocoapods/new_architecture.rb +57 -74
- package/scripts/cocoapods/utils.rb +137 -65
- package/scripts/codegen/codegen-utils.js +14 -0
- package/scripts/codegen/generate-artifacts-executor.js +465 -373
- package/scripts/codegen/generate-specs-cli-executor.js +25 -24
- package/scripts/codegen/templates/RCTModulesConformingToProtocolsProviderH.template +18 -0
- package/scripts/codegen/templates/RCTModulesConformingToProtocolsProviderMM.template +33 -0
- package/scripts/compose-source-maps.js +2 -2
- package/scripts/generate-codegen-artifacts.js +9 -50
- package/scripts/generate-provider-cli.js +2 -11
- package/scripts/generate-specs-cli.js +1 -1
- package/scripts/hermes/hermes-utils.js +32 -16
- package/scripts/hermes/prepare-hermes-for-build.js +1 -1
- package/scripts/react-native-xcode.sh +4 -4
- package/scripts/react_native_pods.rb +30 -148
- package/scripts/react_native_pods_utils/script_phases.rb +0 -2
- package/scripts/react_native_pods_utils/script_phases.sh +2 -2
- package/scripts/xcode/ccache-clang++.sh +14 -0
- package/scripts/xcode/ccache-clang.sh +14 -0
- package/scripts/xcode/ccache.conf +11 -0
- package/sdks/.hermesversion +1 -1
- package/sdks/hermes-engine/hermes-engine.podspec +0 -1
- package/sdks/hermes-engine/utils/build-apple-framework.sh +1 -0
- package/sdks/hermes-engine/utils/build-hermes-xcode.sh +25 -5
- package/sdks/hermes-engine/utils/build-hermesc-xcode.sh +6 -18
- package/sdks/hermes-engine/utils/build-ios-framework.sh +6 -1
- package/sdks/hermes-engine/utils/build-mac-framework.sh +5 -0
- package/sdks/hermes-engine/utils/create-dummy-hermes-xcframework.sh +6 -4
- package/sdks/hermes-engine/utils/replace_hermes_version.js +2 -2
- package/sdks/hermesc/linux64-bin/hermesc +0 -0
- package/sdks/hermesc/osx-bin/hermes +0 -0
- package/sdks/hermesc/osx-bin/hermesc +0 -0
- package/sdks/hermesc/win64-bin/hermesc.exe +0 -0
- package/settings.gradle.kts +0 -7
- package/{Libraries/Core → src/private/core}/setUpDOM.js +2 -2
- package/src/private/featureflags/NativeReactNativeFeatureFlags.js +42 -0
- package/src/private/featureflags/ReactNativeFeatureFlags.js +140 -0
- package/src/private/featureflags/ReactNativeFeatureFlagsBase.js +84 -0
- package/src/private/featureflags/__tests__/ReactNativeFeatureFlags-test.js +92 -0
- package/src/private/specs/components/ActivityIndicatorViewNativeComponent.js +53 -0
- package/src/private/specs/components/AndroidDrawerLayoutNativeComponent.js +124 -0
- package/src/private/specs/components/AndroidHorizontalScrollContentViewNativeComponent.js +26 -0
- package/src/private/specs/components/AndroidSwipeRefreshLayoutNativeComponent.js +74 -0
- package/src/private/specs/components/AndroidSwitchNativeComponent.js +62 -0
- package/src/private/specs/components/DebuggingOverlayNativeComponent.js +61 -0
- package/src/private/specs/components/ProgressBarAndroidNativeComponent.js +36 -0
- package/src/private/specs/components/PullToRefreshViewNativeComponent.js +71 -0
- package/src/private/specs/components/RCTInputAccessoryViewNativeComponent.js +26 -0
- package/src/private/specs/components/RCTModalHostViewNativeComponent.js +139 -0
- package/src/private/specs/components/RCTSafeAreaViewNativeComponent.js +25 -0
- package/src/private/specs/components/SwitchNativeComponent.js +61 -0
- package/src/private/specs/components/UnimplementedNativeViewNativeComponent.js +26 -0
- package/src/private/specs/modules/NativeAccessibilityInfo.js +33 -0
- package/src/private/specs/modules/NativeAccessibilityManager.js +66 -0
- package/src/private/specs/modules/NativeActionSheetManager.js +54 -0
- package/src/private/specs/modules/NativeAlertManager.js +35 -0
- package/src/private/specs/modules/NativeAnimatedModule.js +77 -0
- package/src/private/specs/modules/NativeAnimatedTurboModule.js +78 -0
- package/src/private/specs/modules/NativeAnimationsDebugModule.js +20 -0
- package/src/private/specs/modules/NativeAppState.js +33 -0
- package/src/private/specs/modules/NativeAppearance.js +36 -0
- package/src/private/specs/modules/NativeBlobModule.js +59 -0
- package/src/private/specs/modules/NativeBugReporting.js +20 -0
- package/src/private/specs/modules/NativeClipboard.js +21 -0
- package/src/private/specs/modules/NativeDevLoadingView.js +24 -0
- package/src/private/specs/modules/NativeDevMenu.js +23 -0
- package/src/private/specs/modules/NativeDevSettings.js +33 -0
- package/src/private/specs/modules/NativeDevToolsSettingsManager.js +24 -0
- package/src/private/specs/modules/NativeDeviceEventManager.js +19 -0
- package/src/private/specs/modules/NativeDeviceInfo.js +58 -0
- package/src/private/specs/modules/NativeDialogManagerAndroid.js +48 -0
- package/src/private/specs/modules/NativeExceptionsManager.js +103 -0
- package/src/private/specs/modules/NativeFileReaderModule.js +22 -0
- package/src/private/specs/modules/NativeFrameRateLogger.js +22 -0
- package/src/private/specs/modules/NativeHeadlessJsTaskSupport.js +20 -0
- package/src/private/specs/modules/NativeI18nManager.js +28 -0
- package/src/private/specs/modules/NativeImageEditor.js +52 -0
- package/src/private/specs/modules/NativeImageLoaderAndroid.js +30 -0
- package/src/private/specs/modules/NativeImageLoaderIOS.js +37 -0
- package/src/private/specs/modules/NativeImageStoreAndroid.js +26 -0
- package/src/private/specs/modules/NativeImageStoreIOS.js +33 -0
- package/src/private/specs/modules/NativeIntentAndroid.js +30 -0
- package/src/private/specs/modules/NativeIntersectionObserver.js +41 -0
- package/src/private/specs/modules/NativeJSCHeapCapture.js +19 -0
- package/src/private/specs/modules/NativeJSCSamplingProfiler.js +19 -0
- package/src/private/specs/modules/NativeKeyboardObserver.js +20 -0
- package/src/private/specs/modules/NativeLinkingManager.js +27 -0
- package/src/private/specs/modules/NativeLogBox.js +20 -0
- package/src/private/specs/modules/NativeModalManager.js +21 -0
- package/src/private/specs/modules/NativeMutationObserver.js +58 -0
- package/src/private/specs/modules/NativeNetworkingAndroid.js +37 -0
- package/src/private/specs/modules/NativeNetworkingIOS.js +37 -0
- package/src/private/specs/modules/NativePermissionsAndroid.js +77 -0
- package/src/private/specs/modules/NativePlatformConstantsAndroid.js +44 -0
- package/src/private/specs/modules/NativePlatformConstantsIOS.js +37 -0
- package/src/private/specs/modules/NativePushNotificationManagerIOS.js +107 -0
- package/src/private/specs/modules/NativeRedBox.js +20 -0
- package/src/private/specs/modules/NativeSampleTurboModule.js +53 -0
- package/src/private/specs/modules/NativeSegmentFetcher.js +28 -0
- package/src/private/specs/modules/NativeSettingsManager.js +25 -0
- package/src/private/specs/modules/NativeShareModule.js +23 -0
- package/src/private/specs/modules/NativeSoundManager.js +22 -0
- package/src/private/specs/modules/NativeSourceCode.js +36 -0
- package/src/private/specs/modules/NativeStatusBarManagerAndroid.js +68 -0
- package/src/private/specs/modules/NativeStatusBarManagerIOS.js +89 -0
- package/src/private/specs/modules/NativeTVNavigationEventEmitter.js +20 -0
- package/src/private/specs/modules/NativeTiming.js +26 -0
- package/src/private/specs/modules/NativeToastAndroid.js +38 -0
- package/src/private/specs/modules/NativeUIManager.js +118 -0
- package/src/private/specs/modules/NativeVibration.js +24 -0
- package/src/private/specs/modules/NativeWebSocketModule.js +34 -0
- package/{Libraries/DOM/Nodes → src/private/webapis/dom/nodes}/ReactNativeElement.js +6 -6
- package/{Libraries/DOM/Nodes → src/private/webapis/dom/nodes}/ReadOnlyCharacterData.js +2 -2
- package/{Libraries/DOM/Nodes → src/private/webapis/dom/nodes}/ReadOnlyElement.js +5 -5
- package/{Libraries/DOM/Nodes → src/private/webapis/dom/nodes}/ReadOnlyNode.js +19 -10
- package/{Libraries/DOM/OldStyleCollections → src/private/webapis/dom/oldstylecollections}/DOMRectList.js +1 -1
- package/{Libraries/DOM/OldStyleCollections → src/private/webapis/dom/oldstylecollections}/DOMRectList.js.flow +1 -1
- package/src/private/webapis/dom/oldstylecollections/__tests__/DOMRectList-test.js +85 -0
- package/src/private/webapis/dom/oldstylecollections/__tests__/HTMLCollection-test.js +80 -0
- package/src/private/webapis/dom/oldstylecollections/__tests__/NodeList-test.js +161 -0
- package/{Libraries/WebPerformance → src/private/webapis/performance}/NativePerformance.js +2 -2
- package/{Libraries/WebPerformance → src/private/webapis/performance}/NativePerformanceObserver.cpp +34 -4
- package/{Libraries/WebPerformance → src/private/webapis/performance}/NativePerformanceObserver.h +12 -14
- package/{Libraries/WebPerformance → src/private/webapis/performance}/NativePerformanceObserver.js +3 -2
- package/{Libraries/WebPerformance → src/private/webapis/performance}/Performance.js +2 -2
- package/{Libraries/WebPerformance → src/private/webapis/performance}/PerformanceEntryReporter.cpp +64 -27
- package/{Libraries/WebPerformance → src/private/webapis/performance}/PerformanceEntryReporter.h +16 -5
- package/{Libraries/WebPerformance → src/private/webapis/performance}/PerformanceEventTiming.js +1 -1
- package/{Libraries/WebPerformance → src/private/webapis/performance}/PerformanceObserver.js +21 -2
- package/{Libraries/WebPerformance → src/private/webapis/performance}/RawPerformanceEntry.js +1 -1
- package/{Libraries/WebPerformance → src/private/webapis/performance}/__mocks__/NativePerformanceObserver.js +9 -0
- package/src/private/webapis/performance/__tests__/BoundedConsumableBufferTest.cpp +201 -0
- package/src/private/webapis/performance/__tests__/EventCounts-test.js +116 -0
- package/src/private/webapis/performance/__tests__/NativePerformanceMock-test.js +82 -0
- package/src/private/webapis/performance/__tests__/NativePerformanceObserverMock-test.js +108 -0
- package/src/private/webapis/performance/__tests__/Performance-test.js +117 -0
- package/src/private/webapis/performance/__tests__/PerformanceEntryReporterTest.cpp +373 -0
- package/src/private/webapis/performance/__tests__/PerformanceObserver-test.js +208 -0
- package/template/_gitignore +10 -2
- package/template/android/app/build.gradle +0 -2
- package/template/android/app/src/main/java/com/helloworld/MainApplication.kt +1 -1
- package/template/android/app/src/main/res/drawable/rn_edit_text_material.xml +2 -1
- package/template/android/build.gradle +3 -3
- package/template/android/gradle/wrapper/gradle-wrapper.properties +1 -1
- package/template/android/gradlew +7 -7
- package/template/android/gradlew.bat +10 -10
- package/template/ios/HelloWorld/AppDelegate.mm +2 -2
- package/template/ios/HelloWorld/PrivacyInfo.xcprivacy +38 -0
- package/template/ios/HelloWorld.xcodeproj/project.pbxproj +18 -2
- package/template/ios/Podfile +0 -15
- package/template/metro.config.js +1 -1
- package/template/package.json +6 -6
- package/third-party-podspecs/DoubleConversion.podspec +4 -0
- package/third-party-podspecs/RCT-Folly.podspec +12 -49
- package/third-party-podspecs/fmt.podspec +21 -20
- package/types/index.d.ts +1 -0
- package/types/modules/globals.d.ts +1 -0
- package/Libraries/AppDelegate/RCTLegacyInteropComponents.mm +0 -21
- package/Libraries/Components/Button.flow.js +0 -265
- package/Libraries/Components/ScrollView/ScrollViewViewConfig.js +0 -86
- package/Libraries/Components/TV/NativeTVNavigationEventEmitter.js +0 -24
- package/Libraries/Components/Touchable/Touchable.flow.js +0 -284
- package/Libraries/Components/TraceUpdateOverlay/TraceUpdateOverlay.js +0 -189
- package/Libraries/Components/TraceUpdateOverlay/TraceUpdateOverlayNativeComponent.js +0 -43
- package/Libraries/Image/Image.flow.js +0 -64
- package/Libraries/Inspector/DevtoolsOverlay.js +0 -223
- package/Libraries/Performance/QuickPerformanceLogger.js +0 -142
- package/React/FBReactNativeSpec/FBReactNativeSpec.podspec +0 -58
- package/ReactAndroid/DevExperience.md +0 -23
- package/ReactAndroid/build.gradle +0 -828
- package/ReactAndroid/flipper-integration/build.gradle.kts +0 -64
- package/ReactAndroid/flipper-integration/src/debug/java/com/facebook/react/flipper/ReactNativeFlipper.kt +0 -66
- package/ReactAndroid/flipper-integration/src/release/java/com/facebook/react/flipper/ReactNativeFlipper.kt +0 -23
- package/ReactAndroid/hermes-engine/build.gradle +0 -307
- package/ReactAndroid/src/main/java/com/facebook/react/LazyTurboModuleManagerDelegate.java +0 -104
- package/ReactAndroid/src/main/java/com/facebook/react/ReactInstancePackage.java +0 -32
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/JSCJavaScriptExecutor.java +0 -31
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/JSCJavaScriptExecutorFactory.java +0 -46
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/ReactCallback.java +0 -22
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/UIManagerProvider.java +0 -18
- package/ReactAndroid/src/main/java/com/facebook/react/defaults/DefaultBindingsInstaller.kt +0 -18
- package/ReactAndroid/src/main/java/com/facebook/react/defaults/DefaultJSIModulePackage.kt +0 -59
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/JSException.java +0 -34
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/EmptyReactNativeConfig.java +0 -35
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/FabricJSIModuleProvider.java +0 -70
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/interop/InteropEvent.java +0 -41
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/interop/InteropEventEmitter.java +0 -65
- package/ReactAndroid/src/main/java/com/facebook/react/runtime/.clang-format +0 -91
- package/ReactAndroid/src/main/java/com/facebook/react/touch/JSResponderHandler.java +0 -73
- package/ReactAndroid/src/main/java/com/facebook/react/touch/ReactHitSlopView.java +0 -26
- package/ReactAndroid/src/main/java/com/facebook/react/touch/ReactInterceptingViewGroup.java +0 -32
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/BaseViewManagerAdapter.java +0 -111
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/UIConstantsProvider.java +0 -18
- package/ReactAndroid/src/main/java/com/facebook/react/views/traceupdateoverlay/TraceUpdateOverlay.java +0 -70
- package/ReactAndroid/src/main/java/com/facebook/react/views/traceupdateoverlay/TraceUpdateOverlayManager.java +0 -83
- package/ReactAndroid/src/main/java/com/facebook/react/views/view/ReactMapBufferPropSetter.kt +0 -526
- package/ReactAndroid/src/main/java/com/facebook/react/views/view/ReactMapBufferViewManager.kt +0 -76
- package/ReactAndroid/src/main/java/com/facebook/react/views/view/ReactViewManagerWrapper.kt +0 -101
- package/ReactAndroid/src/main/java/com/facebook/yoga/YogaPrintOptions.java +0 -35
- package/ReactAndroid/src/main/jni/react/fabric/viewPropConversions.h +0 -221
- package/ReactAndroid/src/main/jni/react/jni/CxxModuleWrapper.cpp +0 -57
- package/ReactAndroid/src/main/jni/third-party/libevent/CMakeLists.txt +0 -42
- package/ReactAndroid/src/main/jni/third-party/libevent/evconfig-private.h +0 -49
- package/ReactAndroid/src/main/jni/third-party/libevent/event-config.h +0 -340
- package/ReactAndroid/src/main/res/devsupport/values-as/strings.xml +0 -6
- package/ReactAndroid/src/main/res/devsupport/values-bs/strings.xml +0 -7
- package/ReactAndroid/src/main/res/devsupport/values-ha/strings.xml +0 -8
- package/ReactAndroid/src/main/res/devsupport/values-in/strings.xml +0 -8
- package/ReactAndroid/src/main/res/devsupport/values-jv/strings.xml +0 -8
- package/ReactAndroid/src/main/res/devsupport/values-ku/strings.xml +0 -6
- package/ReactAndroid/src/main/res/devsupport/values-nb/strings.xml +0 -8
- package/ReactAndroid/src/main/res/devsupport/values-ps/strings.xml +0 -6
- package/ReactAndroid/src/main/res/devsupport/values-qz/strings.xml +0 -6
- package/ReactAndroid/src/main/res/devsupport/values-sn/strings.xml +0 -6
- package/ReactAndroid/src/main/res/devsupport/values-so/strings.xml +0 -6
- package/ReactAndroid/src/main/res/devsupport/values-tg/strings.xml +0 -6
- package/ReactAndroid/src/main/res/devsupport/values-tk/strings.xml +0 -6
- package/ReactAndroid/src/main/res/devsupport/values-tl/strings.xml +0 -7
- package/ReactAndroid/src/main/res/devsupport/values-uz/strings.xml +0 -6
- package/ReactAndroid/src/main/res/devsupport/values-wo/strings.xml +0 -6
- package/ReactAndroid/src/main/res/views/uimanager/values-as/strings.xml +0 -13
- package/ReactAndroid/src/main/res/views/uimanager/values-bs/strings.xml +0 -31
- package/ReactAndroid/src/main/res/views/uimanager/values-ha/strings.xml +0 -31
- package/ReactAndroid/src/main/res/views/uimanager/values-in/strings.xml +0 -29
- package/ReactAndroid/src/main/res/views/uimanager/values-jv/strings.xml +0 -28
- package/ReactAndroid/src/main/res/views/uimanager/values-ku/strings.xml +0 -12
- package/ReactAndroid/src/main/res/views/uimanager/values-nb/strings.xml +0 -31
- package/ReactAndroid/src/main/res/views/uimanager/values-ps/strings.xml +0 -13
- package/ReactAndroid/src/main/res/views/uimanager/values-qz/strings.xml +0 -6
- package/ReactAndroid/src/main/res/views/uimanager/values-sn/strings.xml +0 -6
- package/ReactAndroid/src/main/res/views/uimanager/values-so/strings.xml +0 -12
- package/ReactAndroid/src/main/res/views/uimanager/values-tg/strings.xml +0 -12
- package/ReactAndroid/src/main/res/views/uimanager/values-tk/strings.xml +0 -6
- package/ReactAndroid/src/main/res/views/uimanager/values-tl/strings.xml +0 -14
- package/ReactAndroid/src/main/res/views/uimanager/values-uz/strings.xml +0 -13
- package/ReactAndroid/src/main/res/views/uimanager/values-wo/strings.xml +0 -6
- package/ReactCommon/hermes/inspector-modern/.clang-format +0 -87
- package/ReactCommon/hermes/inspector-modern/AsyncPauseState.h +0 -34
- package/ReactCommon/hermes/inspector-modern/Exceptions.h +0 -60
- package/ReactCommon/hermes/inspector-modern/Inspector.cpp +0 -745
- package/ReactCommon/hermes/inspector-modern/Inspector.h +0 -384
- package/ReactCommon/hermes/inspector-modern/InspectorState.cpp +0 -511
- package/ReactCommon/hermes/inspector-modern/InspectorState.h +0 -412
- package/ReactCommon/hermes/inspector-modern/README.md +0 -113
- package/ReactCommon/hermes/inspector-modern/RuntimeAdapter.cpp +0 -30
- package/ReactCommon/hermes/inspector-modern/RuntimeAdapter.h +0 -76
- package/ReactCommon/hermes/inspector-modern/chrome/Connection.cpp +0 -1667
- package/ReactCommon/hermes/inspector-modern/chrome/Connection.h +0 -68
- package/ReactCommon/hermes/inspector-modern/chrome/MessageConverters.cpp +0 -378
- package/ReactCommon/hermes/inspector-modern/chrome/MessageConverters.h +0 -136
- package/ReactCommon/hermes/inspector-modern/chrome/MessageInterfaces.h +0 -74
- package/ReactCommon/hermes/inspector-modern/chrome/MessageTypes.cpp +0 -1948
- package/ReactCommon/hermes/inspector-modern/chrome/MessageTypes.h +0 -1129
- package/ReactCommon/hermes/inspector-modern/chrome/MessageTypesInlines.h +0 -190
- package/ReactCommon/hermes/inspector-modern/chrome/RemoteObjectsTable.cpp +0 -146
- package/ReactCommon/hermes/inspector-modern/chrome/RemoteObjectsTable.h +0 -124
- package/ReactCommon/hermes/inspector-modern/chrome/cli/main.cpp +0 -275
- package/ReactCommon/hermes/inspector-modern/detail/CallbackOStream.cpp +0 -77
- package/ReactCommon/hermes/inspector-modern/detail/CallbackOStream.h +0 -89
- package/ReactCommon/hermes/inspector-modern/detail/SerialExecutor.cpp +0 -60
- package/ReactCommon/hermes/inspector-modern/detail/SerialExecutor.h +0 -57
- package/ReactCommon/hermes/inspector-modern/detail/Thread.cpp +0 -39
- package/ReactCommon/hermes/inspector-modern/detail/Thread.h +0 -85
- package/ReactCommon/hermes/inspector-modern/docs/GenerateInspectorFSM.sh +0 -7
- package/ReactCommon/hermes/inspector-modern/docs/InspectorFSM.gv +0 -39
- package/ReactCommon/hermes/inspector-modern/docs/InspectorFSM.pdf +0 -0
- package/ReactCommon/hermes/inspector-modern/tools/format +0 -10
- package/ReactCommon/hermes/inspector-modern/tools/message_types.txt +0 -41
- package/ReactCommon/hermes/inspector-modern/tools/run_msggen +0 -32
- package/ReactCommon/hermes/inspector-modern/tools/sandcastle/build_and_test.sh +0 -13
- package/ReactCommon/hermes/inspector-modern/tools/sandcastle/setup.sh +0 -31
- package/ReactCommon/react/nativemodule/core/platform/ios/ReactCommon/RCTBlockGuard.h +0 -24
- package/ReactCommon/react/nativemodule/core/platform/ios/ReactCommon/RCTBlockGuard.mm +0 -28
- package/ReactCommon/react/renderer/components/textinput/iostextinput/react/renderer/components/iostextinput/TextInputState.cpp +0 -32
- package/ReactCommon/react/renderer/components/view/platform/android/react/renderer/components/view/AccessibilityPropsMapBuffer.cpp +0 -165
- package/ReactCommon/react/renderer/components/view/platform/android/react/renderer/components/view/AccessibilityPropsMapBuffer.h +0 -35
- package/ReactCommon/react/renderer/components/view/platform/android/react/renderer/components/view/ViewPropsMapBuffer.cpp +0 -191
- package/ReactCommon/react/renderer/components/view/platform/android/react/renderer/components/view/ViewPropsMapBuffer.h +0 -51
- package/ReactCommon/react/renderer/components/view/platform/android/react/renderer/components/view/YogaStylablePropsMapBuffer.cpp +0 -80
- package/ReactCommon/react/renderer/components/view/viewPropConversions.h +0 -214
- package/ReactCommon/react/renderer/core/EventHandler.h +0 -28
- package/ReactCommon/react/renderer/core/PropsParserContext.cpp +0 -27
- package/ReactCommon/react/renderer/core/TraitCast.h +0 -90
- package/ReactCommon/react/renderer/core/tests/traitCastTest.cpp +0 -144
- package/ReactCommon/react/renderer/imagemanager/platform/cxx/react/renderer/imagemanager/ImageRequest.cpp +0 -36
- package/ReactCommon/react/renderer/templateprocessor/CMakeLists.txt +0 -33
- package/ReactCommon/react/renderer/templateprocessor/UITemplateProcessor.cpp +0 -153
- package/ReactCommon/react/renderer/templateprocessor/UITemplateProcessor.h +0 -64
- package/ReactCommon/react/renderer/templateprocessor/tests/UITemplateProcessorTest.cpp +0 -170
- package/ReactCommon/react/renderer/textlayoutmanager/platform/ios/react/renderer/textlayoutmanager/NSTextStorage+FontScaling.h +0 -20
- package/ReactCommon/react/renderer/textlayoutmanager/platform/ios/react/renderer/textlayoutmanager/NSTextStorage+FontScaling.m +0 -117
- package/ReactCommon/react/runtime/JSEngineInstance.h +0 -27
- package/ReactCommon/react/utils/CalledOnceMovableOnlyFunction.h +0 -87
- package/ReactCommon/yoga/yoga/Yoga-internal.h +0 -22
- package/ReactCommon/yoga/yoga/Yoga.cpp +0 -962
- package/ReactCommon/yoga/yoga/algorithm/ResolveValue.h +0 -32
- package/ReactCommon/yoga/yoga/bits/BitCast.h +0 -30
- package/ReactCommon/yoga/yoga/bits/NumericBitfield.h +0 -67
- package/ReactCommon/yoga/yoga/debug/NodeToString.cpp +0 -244
- package/ReactCommon/yoga/yoga/debug/NodeToString.h +0 -29
- package/ReactCommon/yoga/yoga/enums/PrintOptions.h +0 -48
- package/ReactCommon/yoga/yoga/style/CompactValue.h +0 -184
- package/scripts/cocoapods/flipper.rb +0 -107
- package/scripts/codegen/generate-legacy-interop-components.js +0 -129
- /package/Libraries/{RCTRequired/RCTRequired → Required}/RCTRequired.h +0 -0
- /package/Libraries/{RCTRequired → Required}/RCTRequired.podspec +0 -0
- /package/ReactAndroid/src/main/java/com/facebook/react/{turbomodule → internal/turbomodule}/.clang-tidy +0 -0
- /package/ReactCommon/react/renderer/components/textinput/{androidtextinput → platform/android}/react/renderer/components/androidtextinput/AndroidTextInputEventEmitter.h +0 -0
- /package/ReactCommon/react/renderer/components/textinput/{iostextinput → platform/ios}/react/renderer/components/iostextinput/TextInputComponentDescriptor.h +0 -0
- /package/ReactCommon/react/renderer/components/textinput/{iostextinput → platform/ios}/react/renderer/components/iostextinput/TextInputEventEmitter.cpp +0 -0
- /package/ReactCommon/react/renderer/components/textinput/{iostextinput → platform/ios}/react/renderer/components/iostextinput/TextInputEventEmitter.h +0 -0
- /package/ReactCommon/react/renderer/components/textinput/{iostextinput → platform/ios}/react/renderer/components/iostextinput/conversions.h +0 -0
- /package/ReactCommon/react/renderer/components/textinput/{iostextinput → platform/ios}/react/renderer/components/iostextinput/primitives.h +0 -0
- /package/ReactCommon/react/renderer/components/textinput/{iostextinput → platform/ios}/react/renderer/components/iostextinput/propsConversions.h +0 -0
- /package/ReactCommon/react/renderer/imagemanager/{platform/ios/react/renderer/imagemanager/ImageRequest.cpp → ImageRequest.cpp} +0 -0
- /package/{Libraries/DOM/Geometry → src/private/webapis/dom/geometry}/DOMRect.js +0 -0
- /package/{Libraries/DOM/Geometry → src/private/webapis/dom/geometry}/DOMRectReadOnly.js +0 -0
- /package/{Libraries/DOM/Nodes → src/private/webapis/dom/nodes}/ReadOnlyText.js +0 -0
- /package/{Libraries/DOM/Nodes/Utilities → src/private/webapis/dom/nodes/utilities}/Traversal.js +0 -0
- /package/{Libraries/DOM/OldStyleCollections → src/private/webapis/dom/oldstylecollections}/ArrayLikeUtils.js +0 -0
- /package/{Libraries/DOM/OldStyleCollections → src/private/webapis/dom/oldstylecollections}/HTMLCollection.js +0 -0
- /package/{Libraries/DOM/OldStyleCollections → src/private/webapis/dom/oldstylecollections}/HTMLCollection.js.flow +0 -0
- /package/{Libraries/DOM/OldStyleCollections → src/private/webapis/dom/oldstylecollections}/NodeList.js +0 -0
- /package/{Libraries/DOM/OldStyleCollections → src/private/webapis/dom/oldstylecollections}/NodeList.js.flow +0 -0
- /package/{Libraries/WebPerformance → src/private/webapis/performance}/BoundedConsumableBuffer.h +0 -0
- /package/{Libraries/WebPerformance → src/private/webapis/performance}/EventCounts.js +0 -0
- /package/{Libraries/WebPerformance → src/private/webapis/performance}/MemoryInfo.js +0 -0
- /package/{Libraries/WebPerformance → src/private/webapis/performance}/NativePerformance.cpp +0 -0
- /package/{Libraries/WebPerformance → src/private/webapis/performance}/NativePerformance.h +0 -0
- /package/{Libraries/WebPerformance → src/private/webapis/performance}/PerformanceEntry.js +0 -0
- /package/{Libraries/WebPerformance → src/private/webapis/performance}/ReactNativeStartupTiming.js +0 -0
- /package/{Libraries/WebPerformance → src/private/webapis/performance}/__mocks__/NativePerformance.js +0 -0
|
@@ -1,1667 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
3
|
-
*
|
|
4
|
-
* This source code is licensed under the MIT license found in the
|
|
5
|
-
* LICENSE file in the root directory of this source tree.
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
#include "Connection.h"
|
|
9
|
-
|
|
10
|
-
#include <cstdlib>
|
|
11
|
-
#include <mutex>
|
|
12
|
-
#include <sstream>
|
|
13
|
-
|
|
14
|
-
#include <folly/Conv.h>
|
|
15
|
-
#include <folly/Executor.h>
|
|
16
|
-
#include <folly/Function.h>
|
|
17
|
-
#include <folly/json.h>
|
|
18
|
-
#include <glog/logging.h>
|
|
19
|
-
#include <hermes/inspector-modern/Inspector.h>
|
|
20
|
-
#include <hermes/inspector-modern/chrome/MessageConverters.h>
|
|
21
|
-
#include <hermes/inspector-modern/chrome/RemoteObjectsTable.h>
|
|
22
|
-
#include <hermes/inspector-modern/detail/CallbackOStream.h>
|
|
23
|
-
#include <hermes/inspector-modern/detail/SerialExecutor.h>
|
|
24
|
-
#include <hermes/inspector-modern/detail/Thread.h>
|
|
25
|
-
#include <jsi/instrumentation.h>
|
|
26
|
-
#include <optional>
|
|
27
|
-
|
|
28
|
-
namespace facebook {
|
|
29
|
-
namespace hermes {
|
|
30
|
-
namespace inspector_modern {
|
|
31
|
-
namespace chrome {
|
|
32
|
-
|
|
33
|
-
using ::facebook::react::jsinspector_modern::ILocalConnection;
|
|
34
|
-
using ::facebook::react::jsinspector_modern::IRemoteConnection;
|
|
35
|
-
using ::folly::Unit;
|
|
36
|
-
|
|
37
|
-
namespace debugger = ::facebook::hermes::debugger;
|
|
38
|
-
namespace inspector_modern = ::facebook::hermes::inspector_modern;
|
|
39
|
-
namespace m = ::facebook::hermes::inspector_modern::chrome::message;
|
|
40
|
-
|
|
41
|
-
static const char *const kVirtualBreakpointPrefix = "virtualbreakpoint-";
|
|
42
|
-
static const char *const kBeforeScriptWithSourceMapExecution =
|
|
43
|
-
"beforeScriptWithSourceMapExecution";
|
|
44
|
-
static const char *const kUserEnteredScriptPrefix = "userScript";
|
|
45
|
-
|
|
46
|
-
/*
|
|
47
|
-
* Connection::Impl
|
|
48
|
-
*/
|
|
49
|
-
|
|
50
|
-
class Connection::Impl : public inspector_modern::InspectorObserver,
|
|
51
|
-
public message::RequestHandler {
|
|
52
|
-
public:
|
|
53
|
-
Impl(
|
|
54
|
-
std::unique_ptr<RuntimeAdapter> adapter,
|
|
55
|
-
const std::string &title,
|
|
56
|
-
bool waitForDebugger);
|
|
57
|
-
~Impl();
|
|
58
|
-
|
|
59
|
-
HermesRuntime &getRuntime();
|
|
60
|
-
std::string getTitle() const;
|
|
61
|
-
|
|
62
|
-
bool connect(std::unique_ptr<IRemoteConnection> remoteConn);
|
|
63
|
-
bool disconnect();
|
|
64
|
-
void sendMessage(std::string str);
|
|
65
|
-
|
|
66
|
-
/* InspectorObserver overrides */
|
|
67
|
-
void onBreakpointResolved(
|
|
68
|
-
Inspector &inspector,
|
|
69
|
-
const debugger::BreakpointInfo &info) override;
|
|
70
|
-
void onContextCreated(Inspector &inspector) override;
|
|
71
|
-
void onPause(Inspector &inspector, const debugger::ProgramState &state)
|
|
72
|
-
override;
|
|
73
|
-
void onResume(Inspector &inspector) override;
|
|
74
|
-
void onScriptParsed(Inspector &inspector, const ScriptInfo &info) override;
|
|
75
|
-
void onMessageAdded(Inspector &inspector, const ConsoleMessageInfo &info)
|
|
76
|
-
override;
|
|
77
|
-
|
|
78
|
-
/* RequestHandler overrides */
|
|
79
|
-
void handle(const m::UnknownRequest &req) override;
|
|
80
|
-
void handle(const m::debugger::DisableRequest &req) override;
|
|
81
|
-
void handle(const m::debugger::EnableRequest &req) override;
|
|
82
|
-
void handle(const m::debugger::EvaluateOnCallFrameRequest &req) override;
|
|
83
|
-
void handle(const m::debugger::PauseRequest &req) override;
|
|
84
|
-
void handle(const m::debugger::RemoveBreakpointRequest &req) override;
|
|
85
|
-
void handle(const m::debugger::ResumeRequest &req) override;
|
|
86
|
-
void handle(const m::debugger::SetBreakpointRequest &req) override;
|
|
87
|
-
void handle(const m::debugger::SetBreakpointByUrlRequest &req) override;
|
|
88
|
-
void handle(const m::debugger::SetBreakpointsActiveRequest &req) override;
|
|
89
|
-
void handle(
|
|
90
|
-
const m::debugger::SetInstrumentationBreakpointRequest &req) override;
|
|
91
|
-
void handle(const m::debugger::SetPauseOnExceptionsRequest &req) override;
|
|
92
|
-
void handle(const m::debugger::StepIntoRequest &req) override;
|
|
93
|
-
void handle(const m::debugger::StepOutRequest &req) override;
|
|
94
|
-
void handle(const m::debugger::StepOverRequest &req) override;
|
|
95
|
-
void handle(const m::heapProfiler::TakeHeapSnapshotRequest &req) override;
|
|
96
|
-
void handle(
|
|
97
|
-
const m::heapProfiler::StartTrackingHeapObjectsRequest &req) override;
|
|
98
|
-
void handle(
|
|
99
|
-
const m::heapProfiler::StopTrackingHeapObjectsRequest &req) override;
|
|
100
|
-
void handle(const m::heapProfiler::StartSamplingRequest &req) override;
|
|
101
|
-
void handle(const m::heapProfiler::StopSamplingRequest &req) override;
|
|
102
|
-
void handle(const m::heapProfiler::CollectGarbageRequest &req) override;
|
|
103
|
-
void handle(
|
|
104
|
-
const m::heapProfiler::GetObjectByHeapObjectIdRequest &req) override;
|
|
105
|
-
void handle(const m::heapProfiler::GetHeapObjectIdRequest &req) override;
|
|
106
|
-
void handle(const m::profiler::StartRequest &req) override;
|
|
107
|
-
void handle(const m::profiler::StopRequest &req) override;
|
|
108
|
-
void handle(const m::runtime::CallFunctionOnRequest &req) override;
|
|
109
|
-
void handle(const m::runtime::CompileScriptRequest &req) override;
|
|
110
|
-
void handle(const m::runtime::EvaluateRequest &req) override;
|
|
111
|
-
void handle(const m::runtime::GetHeapUsageRequest &req) override;
|
|
112
|
-
void handle(const m::runtime::GetPropertiesRequest &req) override;
|
|
113
|
-
void handle(const m::runtime::GlobalLexicalScopeNamesRequest &req) override;
|
|
114
|
-
void handle(const m::runtime::RunIfWaitingForDebuggerRequest &req) override;
|
|
115
|
-
|
|
116
|
-
private:
|
|
117
|
-
// The execution context id reported back by the ExecutionContextCreated
|
|
118
|
-
// notification. We only ever expect this execution context id.
|
|
119
|
-
static constexpr int32_t kHermesExecutionContextId = 1;
|
|
120
|
-
std::vector<m::runtime::PropertyDescriptor> makePropsFromScope(
|
|
121
|
-
std::pair<uint32_t, uint32_t> frameAndScopeIndex,
|
|
122
|
-
const std::string &objectGroup,
|
|
123
|
-
const debugger::ProgramState &state,
|
|
124
|
-
bool generatePreview);
|
|
125
|
-
std::vector<m::runtime::PropertyDescriptor> makePropsFromValue(
|
|
126
|
-
const jsi::Value &value,
|
|
127
|
-
const std::string &objectGroup,
|
|
128
|
-
bool onlyOwnProperties,
|
|
129
|
-
bool generatePreview);
|
|
130
|
-
|
|
131
|
-
void sendSnapshot(
|
|
132
|
-
int reqId,
|
|
133
|
-
std::string message,
|
|
134
|
-
bool reportProgress,
|
|
135
|
-
bool stopStackTraceCapture);
|
|
136
|
-
void sendToClient(const std::string &str);
|
|
137
|
-
void sendResponseToClient(const m::Response &resp);
|
|
138
|
-
void sendNotificationToClient(const m::Notification &resp);
|
|
139
|
-
folly::Function<void(const std::exception &)> sendErrorToClient(int id);
|
|
140
|
-
void sendResponseToClientViaExecutor(int id);
|
|
141
|
-
void sendResponseToClientViaExecutor(folly::Future<Unit> future, int id);
|
|
142
|
-
void sendResponseToClientViaExecutor(const m::Response &resp);
|
|
143
|
-
void sendNotificationToClientViaExecutor(const m::Notification ¬e);
|
|
144
|
-
void sendErrorToClientViaExecutor(int id, const std::string &error);
|
|
145
|
-
|
|
146
|
-
template <typename C>
|
|
147
|
-
void runInExecutor(int id, C callback) {
|
|
148
|
-
executor_->add([cb = std::move(callback)]() { cb(); });
|
|
149
|
-
}
|
|
150
|
-
|
|
151
|
-
std::shared_ptr<RuntimeAdapter> runtimeAdapter_;
|
|
152
|
-
std::string title_;
|
|
153
|
-
|
|
154
|
-
// connected_ is protected by connectionMutex_.
|
|
155
|
-
std::mutex connectionMutex_;
|
|
156
|
-
bool connected_;
|
|
157
|
-
|
|
158
|
-
// parsedScripts_ list stores file names of all scripts that have been
|
|
159
|
-
// parsed so that we could find script's file name by regex.
|
|
160
|
-
// This is similar to Inspector's loadedScripts_ map but we want to
|
|
161
|
-
// store this info here because searching file name that matches
|
|
162
|
-
// given regex (on setBreakpointByUrl command) is more related to Chrome
|
|
163
|
-
// protocol than to Hermes inspector.
|
|
164
|
-
// Access is protected by parsedScriptsMutex_.
|
|
165
|
-
std::mutex parsedScriptsMutex_;
|
|
166
|
-
std::vector<std::string> parsedScripts_;
|
|
167
|
-
|
|
168
|
-
// preparedScripts_ stores user-entered scripts that have been prepared for
|
|
169
|
-
// execution, and may be invoked by a later command.
|
|
170
|
-
std::vector<std::shared_ptr<const jsi::PreparedJavaScript>> preparedScripts_;
|
|
171
|
-
|
|
172
|
-
// Some events are represented as a mode in Hermes but a breakpoint in CDP,
|
|
173
|
-
// e.g. "beforeScriptExecution" and "beforeScriptWithSourceMapExecution".
|
|
174
|
-
// Keep track of these separately. The caller should lock the
|
|
175
|
-
// virtualBreakpointMutex_.
|
|
176
|
-
std::mutex virtualBreakpointMutex_;
|
|
177
|
-
uint32_t nextVirtualBreakpoint_ = 1;
|
|
178
|
-
const std::string &createVirtualBreakpoint(const std::string &category);
|
|
179
|
-
bool isVirtualBreakpointId(const std::string &id);
|
|
180
|
-
bool hasVirtualBreakpoint(const std::string &category);
|
|
181
|
-
bool removeVirtualBreakpoint(const std::string &id);
|
|
182
|
-
std::unordered_map<std::string, std::unordered_set<std::string>>
|
|
183
|
-
virtualBreakpoints_;
|
|
184
|
-
|
|
185
|
-
// The rest of these member variables are only accessed via executor_.
|
|
186
|
-
std::unique_ptr<folly::Executor> executor_;
|
|
187
|
-
std::unique_ptr<IRemoteConnection> remoteConn_;
|
|
188
|
-
std::shared_ptr<inspector_modern::Inspector> inspector_;
|
|
189
|
-
|
|
190
|
-
// objTable_ is protected by the inspector lock. It should only be accessed
|
|
191
|
-
// when the VM is paused, e.g. in an InspectorObserver callback or in an
|
|
192
|
-
// executeIfEnabled callback.
|
|
193
|
-
RemoteObjectsTable objTable_;
|
|
194
|
-
};
|
|
195
|
-
|
|
196
|
-
Connection::Impl::Impl(
|
|
197
|
-
std::unique_ptr<RuntimeAdapter> adapter,
|
|
198
|
-
const std::string &title,
|
|
199
|
-
bool waitForDebugger)
|
|
200
|
-
: runtimeAdapter_(std::move(adapter)),
|
|
201
|
-
title_(title),
|
|
202
|
-
connected_(false),
|
|
203
|
-
executor_(std::make_unique<inspector_modern::detail::SerialExecutor>(
|
|
204
|
-
"hermes-chrome-inspector-conn")),
|
|
205
|
-
remoteConn_(nullptr),
|
|
206
|
-
inspector_(std::make_shared<inspector_modern::Inspector>(
|
|
207
|
-
runtimeAdapter_,
|
|
208
|
-
*this,
|
|
209
|
-
waitForDebugger)) {
|
|
210
|
-
inspector_->installLogHandler();
|
|
211
|
-
}
|
|
212
|
-
|
|
213
|
-
Connection::Impl::~Impl() = default;
|
|
214
|
-
|
|
215
|
-
HermesRuntime &Connection::Impl::getRuntime() {
|
|
216
|
-
return runtimeAdapter_->getRuntime();
|
|
217
|
-
}
|
|
218
|
-
|
|
219
|
-
std::string Connection::Impl::getTitle() const {
|
|
220
|
-
return title_;
|
|
221
|
-
}
|
|
222
|
-
|
|
223
|
-
bool Connection::Impl::connect(std::unique_ptr<IRemoteConnection> remoteConn) {
|
|
224
|
-
assert(remoteConn);
|
|
225
|
-
std::scoped_lock lock(connectionMutex_);
|
|
226
|
-
|
|
227
|
-
if (connected_) {
|
|
228
|
-
return false;
|
|
229
|
-
}
|
|
230
|
-
|
|
231
|
-
connected_ = true;
|
|
232
|
-
executor_->add([this, remoteConn = std::move(remoteConn)]() mutable {
|
|
233
|
-
remoteConn_ = std::move(remoteConn);
|
|
234
|
-
});
|
|
235
|
-
|
|
236
|
-
return true;
|
|
237
|
-
}
|
|
238
|
-
|
|
239
|
-
bool Connection::Impl::disconnect() {
|
|
240
|
-
std::scoped_lock lock(connectionMutex_);
|
|
241
|
-
|
|
242
|
-
if (!connected_) {
|
|
243
|
-
return false;
|
|
244
|
-
}
|
|
245
|
-
|
|
246
|
-
connected_ = false;
|
|
247
|
-
|
|
248
|
-
inspector_->disable().via(executor_.get()).thenValue([this](auto &&) {
|
|
249
|
-
// HACK: We purposely call RemoteConnection::onDisconnect on a *different*
|
|
250
|
-
// thread, rather than on this thread (the executor thread). This is to
|
|
251
|
-
// prevent this scenario:
|
|
252
|
-
//
|
|
253
|
-
// 1. RemoteConnection::onDisconnect runs on the executor thread
|
|
254
|
-
// 2. onDisconnect through a long chain of calls causes the Connection
|
|
255
|
-
// destructor to run
|
|
256
|
-
// 3. The Connection destructor causes the SerialExecutor destructor to run.
|
|
257
|
-
// 4. The SerialExecutor destructor waits for all outstanding work items to
|
|
258
|
-
// finish via a call to join().
|
|
259
|
-
// 5. join() fails, since the executor thread is trying to join against
|
|
260
|
-
// itself.
|
|
261
|
-
//
|
|
262
|
-
// To prevent this chain of events, we always call onDisconnect on a
|
|
263
|
-
// different thread.
|
|
264
|
-
//
|
|
265
|
-
// See P59135203 for an example stack trace.
|
|
266
|
-
//
|
|
267
|
-
// One more hack: we use release() and delete instead of unique_ptr because
|
|
268
|
-
// detail::Thread expects a std::function, and std::function cannot capture
|
|
269
|
-
// move-only types like unique_ptr.
|
|
270
|
-
auto conn = remoteConn_.release();
|
|
271
|
-
inspector_modern::detail::Thread disconnectLaterThread{
|
|
272
|
-
"hermes-chrome-inspector-conn-disconnect", [conn] {
|
|
273
|
-
conn->onDisconnect();
|
|
274
|
-
delete conn;
|
|
275
|
-
}};
|
|
276
|
-
disconnectLaterThread.detach();
|
|
277
|
-
});
|
|
278
|
-
|
|
279
|
-
return true;
|
|
280
|
-
}
|
|
281
|
-
|
|
282
|
-
void Connection::Impl::sendMessage(std::string str) {
|
|
283
|
-
executor_->add([this, str = std::move(str)]() mutable {
|
|
284
|
-
folly::Try<std::unique_ptr<m::Request>> maybeReq =
|
|
285
|
-
m::Request::fromJson(str);
|
|
286
|
-
|
|
287
|
-
if (maybeReq.hasException()) {
|
|
288
|
-
LOG(ERROR) << "Invalid request `" << str
|
|
289
|
-
<< "`: " << maybeReq.exception().what();
|
|
290
|
-
return;
|
|
291
|
-
}
|
|
292
|
-
|
|
293
|
-
auto &req = maybeReq.value();
|
|
294
|
-
if (req) {
|
|
295
|
-
req->accept(*this);
|
|
296
|
-
}
|
|
297
|
-
});
|
|
298
|
-
}
|
|
299
|
-
|
|
300
|
-
/*
|
|
301
|
-
* InspectorObserver overrides
|
|
302
|
-
*/
|
|
303
|
-
|
|
304
|
-
void Connection::Impl::onBreakpointResolved(
|
|
305
|
-
Inspector &inspector,
|
|
306
|
-
const debugger::BreakpointInfo &info) {
|
|
307
|
-
m::debugger::BreakpointResolvedNotification note;
|
|
308
|
-
note.breakpointId = folly::to<std::string>(info.id);
|
|
309
|
-
note.location = m::debugger::makeLocation(info.resolvedLocation);
|
|
310
|
-
sendNotificationToClientViaExecutor(note);
|
|
311
|
-
}
|
|
312
|
-
|
|
313
|
-
void Connection::Impl::onContextCreated(Inspector &inspector) {
|
|
314
|
-
// Right now, Hermes only has the notion of one JS context per VM instance,
|
|
315
|
-
// so we just always name the single JS context with id=1 and name=hermes.
|
|
316
|
-
m::runtime::ExecutionContextCreatedNotification note;
|
|
317
|
-
note.context.id = kHermesExecutionContextId;
|
|
318
|
-
note.context.name = "hermes";
|
|
319
|
-
|
|
320
|
-
sendNotificationToClientViaExecutor(note);
|
|
321
|
-
}
|
|
322
|
-
|
|
323
|
-
void Connection::Impl::onPause(
|
|
324
|
-
Inspector &inspector,
|
|
325
|
-
const debugger::ProgramState &state) {
|
|
326
|
-
bool sendNotification = true;
|
|
327
|
-
m::debugger::PausedNotification note;
|
|
328
|
-
note.callFrames = m::debugger::makeCallFrames(state, objTable_, getRuntime());
|
|
329
|
-
|
|
330
|
-
switch (state.getPauseReason()) {
|
|
331
|
-
case debugger::PauseReason::Breakpoint:
|
|
332
|
-
// use other, chrome protocol has no reason specifically for breakpoints
|
|
333
|
-
note.reason = "other";
|
|
334
|
-
|
|
335
|
-
// TODO: hermes hasn't implemented ProgramState::getBreakpoint yet
|
|
336
|
-
#if HERMES_SUPPORTS_STATE_GET_BREAKPOINT
|
|
337
|
-
note.hitBreakpoints = std::vector<m::debugger::BreakpointId>();
|
|
338
|
-
note.hitBreakpoints->emplace_back(
|
|
339
|
-
folly::to<std::string>(state.getBreakpoint()));
|
|
340
|
-
#endif
|
|
341
|
-
|
|
342
|
-
break;
|
|
343
|
-
case debugger::PauseReason::Exception:
|
|
344
|
-
note.reason = "exception";
|
|
345
|
-
break;
|
|
346
|
-
case debugger::PauseReason::ScriptLoaded: {
|
|
347
|
-
// This case covers both wait-for-debugger and instrumentation
|
|
348
|
-
// breakpoints, since both are implemented as pauses on script load.
|
|
349
|
-
|
|
350
|
-
note.reason = "other";
|
|
351
|
-
note.hitBreakpoints = std::vector<m::debugger::BreakpointId>();
|
|
352
|
-
|
|
353
|
-
std::scoped_lock lock(virtualBreakpointMutex_);
|
|
354
|
-
for (auto &bp :
|
|
355
|
-
virtualBreakpoints_[kBeforeScriptWithSourceMapExecution]) {
|
|
356
|
-
note.hitBreakpoints->emplace_back(bp);
|
|
357
|
-
}
|
|
358
|
-
|
|
359
|
-
// Debuggers don't tend to ever remove these kinds of breakpoints, but
|
|
360
|
-
// in the extremely unlikely event that it did *and* did it exactly
|
|
361
|
-
// between us 1. checking that we should stop, and 2. adding the stop
|
|
362
|
-
// reason here, then just resume and skip sending a pause notification.
|
|
363
|
-
if (!inspector_->isAwaitingDebuggerOnStart() &&
|
|
364
|
-
note.hitBreakpoints->empty()) {
|
|
365
|
-
sendNotification = false;
|
|
366
|
-
inspector_->resume();
|
|
367
|
-
}
|
|
368
|
-
};
|
|
369
|
-
// This will be toggled back on in the next onScriptParsed if applicable
|
|
370
|
-
// Locking is handled by didPause in the inspector
|
|
371
|
-
inspector_->setPauseOnLoads(PauseOnLoadMode::None);
|
|
372
|
-
break;
|
|
373
|
-
default:
|
|
374
|
-
note.reason = "other";
|
|
375
|
-
break;
|
|
376
|
-
}
|
|
377
|
-
|
|
378
|
-
if (sendNotification) {
|
|
379
|
-
sendNotificationToClientViaExecutor(note);
|
|
380
|
-
}
|
|
381
|
-
}
|
|
382
|
-
|
|
383
|
-
void Connection::Impl::onResume(Inspector &inspector) {
|
|
384
|
-
objTable_.releaseObjectGroup(BacktraceObjectGroup);
|
|
385
|
-
|
|
386
|
-
m::debugger::ResumedNotification note;
|
|
387
|
-
sendNotificationToClientViaExecutor(note);
|
|
388
|
-
}
|
|
389
|
-
|
|
390
|
-
void Connection::Impl::onScriptParsed(
|
|
391
|
-
Inspector &inspector,
|
|
392
|
-
const ScriptInfo &info) {
|
|
393
|
-
m::debugger::ScriptParsedNotification note;
|
|
394
|
-
note.scriptId = folly::to<std::string>(info.fileId);
|
|
395
|
-
note.url = info.fileName;
|
|
396
|
-
note.executionContextId = kHermesExecutionContextId;
|
|
397
|
-
|
|
398
|
-
if (!info.sourceMappingUrl.empty()) {
|
|
399
|
-
note.sourceMapURL = info.sourceMappingUrl;
|
|
400
|
-
|
|
401
|
-
std::scoped_lock lock(virtualBreakpointMutex_);
|
|
402
|
-
if (hasVirtualBreakpoint(kBeforeScriptWithSourceMapExecution)) {
|
|
403
|
-
// We are precariously relying on the fact that onScriptParsed
|
|
404
|
-
// is invoked immediately before the pause load mode is checked.
|
|
405
|
-
// That means that we can check for breakpoints and toggle the
|
|
406
|
-
// mode here, and then immediately turn it off in onPause.
|
|
407
|
-
inspector_->setPauseOnLoads(PauseOnLoadMode::All);
|
|
408
|
-
}
|
|
409
|
-
}
|
|
410
|
-
|
|
411
|
-
{
|
|
412
|
-
std::scoped_lock lock(parsedScriptsMutex_);
|
|
413
|
-
parsedScripts_.push_back(info.fileName);
|
|
414
|
-
}
|
|
415
|
-
|
|
416
|
-
sendNotificationToClientViaExecutor(note);
|
|
417
|
-
}
|
|
418
|
-
|
|
419
|
-
void Connection::Impl::onMessageAdded(
|
|
420
|
-
facebook::hermes::inspector_modern::Inspector &inspector,
|
|
421
|
-
const ConsoleMessageInfo &info) {
|
|
422
|
-
m::runtime::ConsoleAPICalledNotification apiCalledNote;
|
|
423
|
-
apiCalledNote.type = info.level;
|
|
424
|
-
apiCalledNote.timestamp =
|
|
425
|
-
std::chrono::duration<double, std::ratio<1, 1000>>(
|
|
426
|
-
std::chrono::system_clock::now().time_since_epoch())
|
|
427
|
-
.count();
|
|
428
|
-
// TODO(jpporto): fix test cases sending invalid context id.
|
|
429
|
-
// apiCalledNote.executionContextId = kHermesExecutionContextId;
|
|
430
|
-
|
|
431
|
-
size_t argsSize = info.args.size(getRuntime());
|
|
432
|
-
for (size_t index = 0; index < argsSize; ++index) {
|
|
433
|
-
apiCalledNote.args.push_back(m::runtime::makeRemoteObject(
|
|
434
|
-
getRuntime(),
|
|
435
|
-
info.args.getValueAtIndex(getRuntime(), index),
|
|
436
|
-
objTable_,
|
|
437
|
-
"ConsoleObjectGroup",
|
|
438
|
-
false,
|
|
439
|
-
false));
|
|
440
|
-
}
|
|
441
|
-
|
|
442
|
-
sendNotificationToClientViaExecutor(apiCalledNote);
|
|
443
|
-
}
|
|
444
|
-
|
|
445
|
-
/*
|
|
446
|
-
* RequestHandler overrides
|
|
447
|
-
*/
|
|
448
|
-
|
|
449
|
-
void Connection::Impl::handle(const m::UnknownRequest &req) {
|
|
450
|
-
LOG(INFO) << "responding ok to unknown request: " << req.toDynamic();
|
|
451
|
-
sendResponseToClientViaExecutor(req.id);
|
|
452
|
-
}
|
|
453
|
-
|
|
454
|
-
void Connection::Impl::handle(const m::debugger::DisableRequest &req) {
|
|
455
|
-
sendResponseToClientViaExecutor(inspector_->disable(), req.id);
|
|
456
|
-
}
|
|
457
|
-
|
|
458
|
-
void Connection::Impl::handle(const m::debugger::EnableRequest &req) {
|
|
459
|
-
sendResponseToClientViaExecutor(inspector_->enable(), req.id);
|
|
460
|
-
}
|
|
461
|
-
|
|
462
|
-
void Connection::Impl::handle(
|
|
463
|
-
const m::debugger::EvaluateOnCallFrameRequest &req) {
|
|
464
|
-
auto remoteObjPtr = std::make_shared<m::runtime::RemoteObject>();
|
|
465
|
-
|
|
466
|
-
inspector_
|
|
467
|
-
->evaluate(
|
|
468
|
-
atoi(req.callFrameId.c_str()),
|
|
469
|
-
req.expression,
|
|
470
|
-
[this,
|
|
471
|
-
remoteObjPtr,
|
|
472
|
-
objectGroup = req.objectGroup,
|
|
473
|
-
byValue = req.returnByValue.value_or(false),
|
|
474
|
-
generatePreview = req.generatePreview.value_or(false)](
|
|
475
|
-
const facebook::hermes::debugger::EvalResult
|
|
476
|
-
&evalResult) mutable {
|
|
477
|
-
*remoteObjPtr = m::runtime::makeRemoteObject(
|
|
478
|
-
getRuntime(),
|
|
479
|
-
evalResult.value,
|
|
480
|
-
objTable_,
|
|
481
|
-
objectGroup.value_or(""),
|
|
482
|
-
byValue,
|
|
483
|
-
generatePreview);
|
|
484
|
-
})
|
|
485
|
-
.via(executor_.get())
|
|
486
|
-
.thenValue(
|
|
487
|
-
[this, id = req.id, remoteObjPtr](debugger::EvalResult result) {
|
|
488
|
-
m::debugger::EvaluateOnCallFrameResponse resp;
|
|
489
|
-
resp.id = id;
|
|
490
|
-
|
|
491
|
-
if (result.isException) {
|
|
492
|
-
resp.exceptionDetails =
|
|
493
|
-
m::runtime::makeExceptionDetails(result.exceptionDetails);
|
|
494
|
-
} else {
|
|
495
|
-
resp.result = std::move(*remoteObjPtr);
|
|
496
|
-
}
|
|
497
|
-
|
|
498
|
-
sendResponseToClient(resp);
|
|
499
|
-
})
|
|
500
|
-
.thenError<std::exception>(sendErrorToClient(req.id));
|
|
501
|
-
}
|
|
502
|
-
|
|
503
|
-
void Connection::Impl::sendSnapshot(
|
|
504
|
-
int reqId,
|
|
505
|
-
std::string message,
|
|
506
|
-
bool reportProgress,
|
|
507
|
-
bool stopStackTraceCapture) {
|
|
508
|
-
inspector_
|
|
509
|
-
->executeIfEnabled(
|
|
510
|
-
message,
|
|
511
|
-
[this, reportProgress, stopStackTraceCapture](
|
|
512
|
-
const debugger::ProgramState &) {
|
|
513
|
-
// Stop taking any new traces before sending out the heap snapshot.
|
|
514
|
-
if (stopStackTraceCapture) {
|
|
515
|
-
getRuntime()
|
|
516
|
-
.instrumentation()
|
|
517
|
-
.stopTrackingHeapObjectStackTraces();
|
|
518
|
-
}
|
|
519
|
-
|
|
520
|
-
if (reportProgress) {
|
|
521
|
-
// A progress notification with finished = true indicates the
|
|
522
|
-
// snapshot has been captured and is ready to be sent. Our
|
|
523
|
-
// implementation streams the snapshot as it is being captured, so
|
|
524
|
-
// we must send this notification first.
|
|
525
|
-
m::heapProfiler::ReportHeapSnapshotProgressNotification note;
|
|
526
|
-
note.done = 1;
|
|
527
|
-
note.total = 1;
|
|
528
|
-
note.finished = true;
|
|
529
|
-
sendNotificationToClient(note);
|
|
530
|
-
}
|
|
531
|
-
|
|
532
|
-
// Size picked to conform to Chrome's own implementation, at the
|
|
533
|
-
// time of writing.
|
|
534
|
-
inspector_modern::detail::CallbackOStream cos(
|
|
535
|
-
/* sz */ 100 << 10, [this](std::string s) {
|
|
536
|
-
m::heapProfiler::AddHeapSnapshotChunkNotification note;
|
|
537
|
-
note.chunk = std::move(s);
|
|
538
|
-
sendNotificationToClient(note);
|
|
539
|
-
return true;
|
|
540
|
-
});
|
|
541
|
-
|
|
542
|
-
getRuntime().instrumentation().createSnapshotToStream(cos);
|
|
543
|
-
})
|
|
544
|
-
.via(executor_.get())
|
|
545
|
-
.thenValue([this, reqId](auto &&) {
|
|
546
|
-
sendResponseToClient(m::makeOkResponse(reqId));
|
|
547
|
-
})
|
|
548
|
-
.thenError<std::exception>(sendErrorToClient(reqId));
|
|
549
|
-
}
|
|
550
|
-
|
|
551
|
-
void Connection::Impl::handle(
|
|
552
|
-
const m::heapProfiler::TakeHeapSnapshotRequest &req) {
|
|
553
|
-
sendSnapshot(
|
|
554
|
-
req.id,
|
|
555
|
-
"HeapSnapshot.takeHeapSnapshot",
|
|
556
|
-
req.reportProgress && *req.reportProgress,
|
|
557
|
-
/* stopStackTraceCapture */ false);
|
|
558
|
-
}
|
|
559
|
-
|
|
560
|
-
void Connection::Impl::handle(
|
|
561
|
-
const m::heapProfiler::StartTrackingHeapObjectsRequest &req) {
|
|
562
|
-
const auto id = req.id;
|
|
563
|
-
|
|
564
|
-
inspector_
|
|
565
|
-
->executeIfEnabled(
|
|
566
|
-
"HeapProfiler.startTrackingHeapObjects",
|
|
567
|
-
[this](const debugger::ProgramState &) {
|
|
568
|
-
getRuntime().instrumentation().startTrackingHeapObjectStackTraces(
|
|
569
|
-
[this](
|
|
570
|
-
uint64_t lastSeenObjectId,
|
|
571
|
-
std::chrono::microseconds timestamp,
|
|
572
|
-
std::vector<jsi::Instrumentation::HeapStatsUpdate> stats) {
|
|
573
|
-
// Send the last object ID notification first.
|
|
574
|
-
m::heapProfiler::LastSeenObjectIdNotification note;
|
|
575
|
-
note.lastSeenObjectId = lastSeenObjectId;
|
|
576
|
-
// The protocol uses milliseconds with a fraction for
|
|
577
|
-
// microseconds.
|
|
578
|
-
note.timestamp =
|
|
579
|
-
static_cast<double>(timestamp.count()) / 1000;
|
|
580
|
-
sendNotificationToClient(note);
|
|
581
|
-
|
|
582
|
-
m::heapProfiler::HeapStatsUpdateNotification heapStatsNote;
|
|
583
|
-
// Flatten the HeapStatsUpdate list.
|
|
584
|
-
heapStatsNote.statsUpdate.reserve(stats.size() * 3);
|
|
585
|
-
for (const jsi::Instrumentation::HeapStatsUpdate &fragment :
|
|
586
|
-
stats) {
|
|
587
|
-
// Each triplet is the fragment number, the total count of
|
|
588
|
-
// objects for the fragment, and the total size of objects
|
|
589
|
-
// for the fragment.
|
|
590
|
-
heapStatsNote.statsUpdate.push_back(
|
|
591
|
-
static_cast<int>(std::get<0>(fragment)));
|
|
592
|
-
heapStatsNote.statsUpdate.push_back(
|
|
593
|
-
static_cast<int>(std::get<1>(fragment)));
|
|
594
|
-
heapStatsNote.statsUpdate.push_back(
|
|
595
|
-
static_cast<int>(std::get<2>(fragment)));
|
|
596
|
-
}
|
|
597
|
-
assert(
|
|
598
|
-
heapStatsNote.statsUpdate.size() == stats.size() * 3 &&
|
|
599
|
-
"Should be exactly 3x the stats vector");
|
|
600
|
-
// TODO: Chunk this if there are too many fragments to update.
|
|
601
|
-
// Unlikely to be a problem in practice unless there's a huge
|
|
602
|
-
// amount of allocation and freeing.
|
|
603
|
-
sendNotificationToClient(heapStatsNote);
|
|
604
|
-
});
|
|
605
|
-
// At this point we need the equivalent of a setInterval, where each
|
|
606
|
-
// interval samples the existing
|
|
607
|
-
})
|
|
608
|
-
.via(executor_.get())
|
|
609
|
-
.thenValue(
|
|
610
|
-
[this, id](auto &&) { sendResponseToClient(m::makeOkResponse(id)); })
|
|
611
|
-
.thenError<std::exception>(sendErrorToClient(req.id));
|
|
612
|
-
}
|
|
613
|
-
|
|
614
|
-
void Connection::Impl::handle(
|
|
615
|
-
const m::heapProfiler::StopTrackingHeapObjectsRequest &req) {
|
|
616
|
-
sendSnapshot(
|
|
617
|
-
req.id,
|
|
618
|
-
"HeapSnapshot.stopTrackingHeapObjects",
|
|
619
|
-
req.reportProgress && *req.reportProgress,
|
|
620
|
-
/* stopStackTraceCapture */ true);
|
|
621
|
-
}
|
|
622
|
-
|
|
623
|
-
void Connection::Impl::handle(
|
|
624
|
-
const m::heapProfiler::StartSamplingRequest &req) {
|
|
625
|
-
const auto id = req.id;
|
|
626
|
-
// This is the same default sampling interval that Chrome uses.
|
|
627
|
-
// https://chromedevtools.github.io/devtools-protocol/tot/HeapProfiler/#method-startSampling
|
|
628
|
-
constexpr size_t kDefaultSamplingInterval = 1 << 15;
|
|
629
|
-
const size_t samplingInterval =
|
|
630
|
-
req.samplingInterval.value_or(kDefaultSamplingInterval);
|
|
631
|
-
|
|
632
|
-
inspector_
|
|
633
|
-
->executeIfEnabled(
|
|
634
|
-
"HeapProfiler.startSampling",
|
|
635
|
-
[this, samplingInterval](const debugger::ProgramState &) {
|
|
636
|
-
getRuntime().instrumentation().startHeapSampling(samplingInterval);
|
|
637
|
-
})
|
|
638
|
-
.via(executor_.get())
|
|
639
|
-
.thenValue(
|
|
640
|
-
[this, id](auto &&) { sendResponseToClient(m::makeOkResponse(id)); })
|
|
641
|
-
.thenError<std::exception>(sendErrorToClient(req.id));
|
|
642
|
-
}
|
|
643
|
-
|
|
644
|
-
void Connection::Impl::handle(const m::heapProfiler::StopSamplingRequest &req) {
|
|
645
|
-
inspector_
|
|
646
|
-
->executeIfEnabled(
|
|
647
|
-
"HeapProfiler.stopSampling",
|
|
648
|
-
[this, id = req.id](const debugger::ProgramState &) {
|
|
649
|
-
std::ostringstream stream;
|
|
650
|
-
getRuntime().instrumentation().stopHeapSampling(stream);
|
|
651
|
-
folly::dynamic json = folly::parseJson(stream.str());
|
|
652
|
-
m::heapProfiler::StopSamplingResponse resp;
|
|
653
|
-
resp.id = id;
|
|
654
|
-
m::heapProfiler::SamplingHeapProfile profile{json};
|
|
655
|
-
resp.profile = std::move(profile);
|
|
656
|
-
sendResponseToClient(resp);
|
|
657
|
-
})
|
|
658
|
-
.via(executor_.get())
|
|
659
|
-
.thenError<std::exception>(sendErrorToClient(req.id));
|
|
660
|
-
}
|
|
661
|
-
|
|
662
|
-
void Connection::Impl::handle(
|
|
663
|
-
const m::heapProfiler::CollectGarbageRequest &req) {
|
|
664
|
-
const auto id = req.id;
|
|
665
|
-
|
|
666
|
-
inspector_
|
|
667
|
-
->executeIfEnabled(
|
|
668
|
-
"HeapProfiler.collectGarbage",
|
|
669
|
-
[this](const debugger::ProgramState &) {
|
|
670
|
-
getRuntime().instrumentation().collectGarbage("inspector");
|
|
671
|
-
})
|
|
672
|
-
.via(executor_.get())
|
|
673
|
-
.thenValue(
|
|
674
|
-
[this, id](auto &&) { sendResponseToClient(m::makeOkResponse(id)); })
|
|
675
|
-
.thenError<std::exception>(sendErrorToClient(req.id));
|
|
676
|
-
}
|
|
677
|
-
|
|
678
|
-
void Connection::Impl::handle(
|
|
679
|
-
const m::heapProfiler::GetObjectByHeapObjectIdRequest &req) {
|
|
680
|
-
uint64_t objID = atoi(req.objectId.c_str());
|
|
681
|
-
std::optional<std::string> group = req.objectGroup;
|
|
682
|
-
auto remoteObjPtr = std::make_shared<m::runtime::RemoteObject>();
|
|
683
|
-
|
|
684
|
-
inspector_
|
|
685
|
-
->executeIfEnabled(
|
|
686
|
-
"HeapProfiler.getObjectByHeapObjectId",
|
|
687
|
-
[this, remoteObjPtr, objID, group](const debugger::ProgramState &) {
|
|
688
|
-
jsi::Runtime *rt = &getRuntime();
|
|
689
|
-
if (auto *hermesRT = dynamic_cast<HermesRuntime *>(rt)) {
|
|
690
|
-
jsi::Value val = hermesRT->getObjectForID(objID);
|
|
691
|
-
if (val.isNull()) {
|
|
692
|
-
return;
|
|
693
|
-
}
|
|
694
|
-
*remoteObjPtr = m::runtime::makeRemoteObject(
|
|
695
|
-
getRuntime(),
|
|
696
|
-
val,
|
|
697
|
-
objTable_,
|
|
698
|
-
group.value_or(""),
|
|
699
|
-
false,
|
|
700
|
-
false);
|
|
701
|
-
}
|
|
702
|
-
})
|
|
703
|
-
.via(executor_.get())
|
|
704
|
-
.thenValue([this, id = req.id, remoteObjPtr](auto &&) {
|
|
705
|
-
if (!remoteObjPtr->type.empty()) {
|
|
706
|
-
m::heapProfiler::GetObjectByHeapObjectIdResponse resp;
|
|
707
|
-
resp.id = id;
|
|
708
|
-
resp.result = std::move(*remoteObjPtr);
|
|
709
|
-
sendResponseToClient(resp);
|
|
710
|
-
} else {
|
|
711
|
-
sendResponseToClient(m::makeErrorResponse(
|
|
712
|
-
id, m::ErrorCode::ServerError, "Object is not available"));
|
|
713
|
-
}
|
|
714
|
-
})
|
|
715
|
-
.thenError<std::exception>(sendErrorToClient(req.id));
|
|
716
|
-
}
|
|
717
|
-
|
|
718
|
-
void Connection::Impl::handle(
|
|
719
|
-
const m::heapProfiler::GetHeapObjectIdRequest &req) {
|
|
720
|
-
// Use a shared_ptr because the stack frame will go away.
|
|
721
|
-
std::shared_ptr<uint64_t> snapshotID = std::make_shared<uint64_t>(0);
|
|
722
|
-
|
|
723
|
-
inspector_
|
|
724
|
-
->executeIfEnabled(
|
|
725
|
-
"HeapProfiler.getHeapObjectId",
|
|
726
|
-
[this, req, snapshotID](const debugger::ProgramState &) {
|
|
727
|
-
if (const jsi::Value *valuePtr = objTable_.getValue(req.objectId)) {
|
|
728
|
-
jsi::Runtime *rt = &getRuntime();
|
|
729
|
-
if (auto *hermesRT = dynamic_cast<HermesRuntime *>(rt)) {
|
|
730
|
-
*snapshotID = hermesRT->getUniqueID(*valuePtr);
|
|
731
|
-
}
|
|
732
|
-
}
|
|
733
|
-
})
|
|
734
|
-
.via(executor_.get())
|
|
735
|
-
.thenValue([this, id = req.id, snapshotID](auto &&) {
|
|
736
|
-
if (*snapshotID) {
|
|
737
|
-
m::heapProfiler::GetHeapObjectIdResponse resp;
|
|
738
|
-
resp.id = id;
|
|
739
|
-
// std::to_string is not available on Android, use a std::ostream
|
|
740
|
-
// instead.
|
|
741
|
-
std::ostringstream stream;
|
|
742
|
-
stream << *snapshotID;
|
|
743
|
-
resp.heapSnapshotObjectId = stream.str();
|
|
744
|
-
sendResponseToClient(resp);
|
|
745
|
-
} else {
|
|
746
|
-
sendResponseToClient(m::makeErrorResponse(
|
|
747
|
-
id, m::ErrorCode::ServerError, "Object is not available"));
|
|
748
|
-
}
|
|
749
|
-
})
|
|
750
|
-
.thenError<std::exception>(sendErrorToClient(req.id));
|
|
751
|
-
}
|
|
752
|
-
|
|
753
|
-
void Connection::Impl::handle(const m::profiler::StartRequest &req) {
|
|
754
|
-
runInExecutor(req.id, [this, id = req.id]() {
|
|
755
|
-
HermesRuntime::enableSamplingProfiler();
|
|
756
|
-
sendResponseToClient(m::makeOkResponse(id));
|
|
757
|
-
});
|
|
758
|
-
}
|
|
759
|
-
|
|
760
|
-
void Connection::Impl::handle(const m::profiler::StopRequest &req) {
|
|
761
|
-
HermesRuntime *hermesRT = &getRuntime();
|
|
762
|
-
|
|
763
|
-
runInExecutor(req.id, [this, id = req.id, hermesRT]() {
|
|
764
|
-
HermesRuntime::disableSamplingProfiler();
|
|
765
|
-
|
|
766
|
-
std::ostringstream profileStream;
|
|
767
|
-
// HermesRuntime instance methods are usually unsafe to be called with a
|
|
768
|
-
// running VM, but sampledTraceToStreamInDevToolsFormat is an exception to
|
|
769
|
-
// that rule -- it synchronizes access to shared resources so it can be
|
|
770
|
-
// safely invoked with a running VM.
|
|
771
|
-
hermesRT->sampledTraceToStreamInDevToolsFormat(profileStream);
|
|
772
|
-
|
|
773
|
-
// Hermes can emit the proper format directly, but it still needs to
|
|
774
|
-
// be parsed into a dynamic.
|
|
775
|
-
try {
|
|
776
|
-
m::profiler::StopResponse resp;
|
|
777
|
-
resp.id = id;
|
|
778
|
-
// parseJson throws on errors, so make sure we don't crash the app
|
|
779
|
-
// if somehow the sampling profiler output is borked.
|
|
780
|
-
resp.profile = m::profiler::Profile(
|
|
781
|
-
folly::parseJson(std::move(profileStream).str()));
|
|
782
|
-
sendResponseToClient(resp);
|
|
783
|
-
} catch (const std::exception &) {
|
|
784
|
-
LOG(ERROR) << "Failed to parse Sampling Profiler output";
|
|
785
|
-
sendResponseToClient(m::makeErrorResponse(
|
|
786
|
-
id,
|
|
787
|
-
m::ErrorCode::InternalError,
|
|
788
|
-
"Hermes profile output could not be parsed."));
|
|
789
|
-
}
|
|
790
|
-
});
|
|
791
|
-
}
|
|
792
|
-
|
|
793
|
-
namespace {
|
|
794
|
-
/// Runtime.CallArguments can have their values specified "inline", or they can
|
|
795
|
-
/// have remote references. The inline values are eval'd together with the
|
|
796
|
-
/// Runtime.CallFunctionOn.functionDeclaration (see CallFunctionOnBuilder
|
|
797
|
-
/// below), while remote object Ids need to be resolved outside of the VM.
|
|
798
|
-
class CallFunctionOnArgument {
|
|
799
|
-
public:
|
|
800
|
-
explicit CallFunctionOnArgument(
|
|
801
|
-
std::optional<m::runtime::RemoteObjectId> maybeObjectId)
|
|
802
|
-
: maybeObjectId_(std::move(maybeObjectId)) {}
|
|
803
|
-
|
|
804
|
-
/// Computes the real value for this argument, which can be an object
|
|
805
|
-
/// referenced by maybeObjectId_, or the given evaldValue. Throws if
|
|
806
|
-
/// maybeObjectId_ is not empty but references an unknown object.
|
|
807
|
-
jsi::Value value(
|
|
808
|
-
jsi::Runtime &rt,
|
|
809
|
-
RemoteObjectsTable &objTable,
|
|
810
|
-
jsi::Value evaldValue) const {
|
|
811
|
-
if (maybeObjectId_) {
|
|
812
|
-
assert(evaldValue.isUndefined() && "expected undefined placeholder");
|
|
813
|
-
return getValueFromId(rt, objTable, *maybeObjectId_);
|
|
814
|
-
}
|
|
815
|
-
|
|
816
|
-
return evaldValue;
|
|
817
|
-
}
|
|
818
|
-
|
|
819
|
-
private:
|
|
820
|
-
/// Returns the jsi::Object for the given objId. Throws if such object can't
|
|
821
|
-
/// be found.
|
|
822
|
-
static jsi::Value getValueFromId(
|
|
823
|
-
jsi::Runtime &rt,
|
|
824
|
-
RemoteObjectsTable &objTable,
|
|
825
|
-
m::runtime::RemoteObjectId objId) {
|
|
826
|
-
if (const jsi::Value *ptr = objTable.getValue(objId)) {
|
|
827
|
-
return jsi::Value(rt, *ptr);
|
|
828
|
-
}
|
|
829
|
-
|
|
830
|
-
throw std::runtime_error("unknown object id " + objId);
|
|
831
|
-
}
|
|
832
|
-
|
|
833
|
-
std::optional<m::runtime::RemoteObjectId> maybeObjectId_;
|
|
834
|
-
};
|
|
835
|
-
|
|
836
|
-
/// Functor that should be used to run the result of eval-ing a CallFunctionOn
|
|
837
|
-
/// request.
|
|
838
|
-
class CallFunctionOnRunner {
|
|
839
|
-
public:
|
|
840
|
-
static constexpr size_t kJsThisIndex = 0;
|
|
841
|
-
static constexpr size_t kFirstArgIndex = 1;
|
|
842
|
-
|
|
843
|
-
// N.B.: constexpr char[] broke react-native-oss-android.
|
|
844
|
-
static const char *kJsThisArgPlaceholder;
|
|
845
|
-
|
|
846
|
-
CallFunctionOnRunner() = default;
|
|
847
|
-
CallFunctionOnRunner(CallFunctionOnRunner &&) = default;
|
|
848
|
-
CallFunctionOnRunner &operator=(CallFunctionOnRunner &&) = default;
|
|
849
|
-
|
|
850
|
-
/// Performs the actual Runtime.CallFunctionOn request. It assumes.
|
|
851
|
-
/// \p evalResult is the result of invoking the Inspector's evaluate() method
|
|
852
|
-
/// on the expression built by the CallFunctionOnBuilder below.
|
|
853
|
-
jsi::Value operator()(
|
|
854
|
-
jsi::Runtime &rt,
|
|
855
|
-
RemoteObjectsTable &objTable,
|
|
856
|
-
const facebook::hermes::debugger::EvalResult &evalResult) {
|
|
857
|
-
// The eval result is an array [a0, a1, ..., an, func] (see
|
|
858
|
-
// CallFunctionOnBuilder below).
|
|
859
|
-
auto argsAndFunc = evalResult.value.getObject(rt).getArray(rt);
|
|
860
|
-
assert(
|
|
861
|
-
argsAndFunc.length(rt) == thisAndArguments_.size() + 1 &&
|
|
862
|
-
"Unexpected result size");
|
|
863
|
-
|
|
864
|
-
// now resolve the arguments to the call, including "this".
|
|
865
|
-
std::vector<jsi::Value> arguments(thisAndArguments_.size() - 1);
|
|
866
|
-
|
|
867
|
-
jsi::Object jsThis =
|
|
868
|
-
getJsThis(rt, objTable, argsAndFunc.getValueAtIndex(rt, kJsThisIndex));
|
|
869
|
-
|
|
870
|
-
int i = kFirstArgIndex;
|
|
871
|
-
for (/*i points to the first param*/; i < thisAndArguments_.size(); ++i) {
|
|
872
|
-
arguments[i - kFirstArgIndex] = thisAndArguments_[i].value(
|
|
873
|
-
rt, objTable, argsAndFunc.getValueAtIndex(rt, i));
|
|
874
|
-
}
|
|
875
|
-
|
|
876
|
-
// i is now func's index.
|
|
877
|
-
jsi::Function func =
|
|
878
|
-
argsAndFunc.getValueAtIndex(rt, i).getObject(rt).getFunction(rt);
|
|
879
|
-
|
|
880
|
-
return func.callWithThis(
|
|
881
|
-
rt,
|
|
882
|
-
std::move(jsThis),
|
|
883
|
-
static_cast<const jsi::Value *>(arguments.data()),
|
|
884
|
-
arguments.size());
|
|
885
|
-
}
|
|
886
|
-
|
|
887
|
-
private:
|
|
888
|
-
friend class CallFunctionOnBuilder;
|
|
889
|
-
|
|
890
|
-
CallFunctionOnRunner(const CallFunctionOnRunner &) = delete;
|
|
891
|
-
CallFunctionOnRunner &operator=(const CallFunctionOnRunner &) = delete;
|
|
892
|
-
|
|
893
|
-
CallFunctionOnRunner(
|
|
894
|
-
std::vector<CallFunctionOnArgument> thisAndArguments,
|
|
895
|
-
std::optional<m::runtime::ExecutionContextId> executionContextId)
|
|
896
|
-
: thisAndArguments_(std::move(thisAndArguments)),
|
|
897
|
-
executionContextId_(std::move(executionContextId)) {}
|
|
898
|
-
|
|
899
|
-
/// Resolves the js "this" for the request, which lives in
|
|
900
|
-
/// thisAndArguments_[kJsThisIndex]. \p evaldThis should either be undefined,
|
|
901
|
-
/// or the placeholder indicating that globalThis should be used.
|
|
902
|
-
jsi::Object getJsThis(
|
|
903
|
-
jsi::Runtime &rt,
|
|
904
|
-
RemoteObjectsTable &objTable,
|
|
905
|
-
jsi::Value evaldThis) const {
|
|
906
|
-
// In the future we may support multiple execution context ids; for now,
|
|
907
|
-
// there's only one.
|
|
908
|
-
(void)executionContextId_;
|
|
909
|
-
|
|
910
|
-
// Either evaldThis is undefined (because the request had an object id
|
|
911
|
-
// specifying "this"), or it should be a string (i.e., the placeholder
|
|
912
|
-
// kJsThisArgPlaceholder).
|
|
913
|
-
assert(
|
|
914
|
-
(evaldThis.isUndefined() ||
|
|
915
|
-
(evaldThis.isString() &&
|
|
916
|
-
evaldThis.getString(rt).utf8(rt) == kJsThisArgPlaceholder)) &&
|
|
917
|
-
"unexpected value for jsThis argument placeholder");
|
|
918
|
-
|
|
919
|
-
// Need to save this information because of the std::move() below.
|
|
920
|
-
const bool useGlobalThis = evaldThis.isString();
|
|
921
|
-
jsi::Value value = thisAndArguments_[kJsThisIndex].value(
|
|
922
|
-
rt, objTable, std::move(evaldThis));
|
|
923
|
-
|
|
924
|
-
return useGlobalThis ? rt.global() : value.getObject(rt);
|
|
925
|
-
}
|
|
926
|
-
|
|
927
|
-
std::vector<CallFunctionOnArgument> thisAndArguments_;
|
|
928
|
-
std::optional<m::runtime::ExecutionContextId> executionContextId_;
|
|
929
|
-
};
|
|
930
|
-
|
|
931
|
-
/*static*/ const char *CallFunctionOnRunner::kJsThisArgPlaceholder =
|
|
932
|
-
"jsThis is Execution Context";
|
|
933
|
-
|
|
934
|
-
/// Returns true if \p str is a number-like string value (e.g., Infinity),
|
|
935
|
-
/// and false otherwise.
|
|
936
|
-
bool unserializableValueLooksLikeNumber(const std::string &str) {
|
|
937
|
-
return str == "Infinity" || str == "-Infinity" || str == "NaN";
|
|
938
|
-
}
|
|
939
|
-
|
|
940
|
-
/// Helper class that processes a Runtime.CallFunctionOn request, and
|
|
941
|
-
/// builds an expression string that, once eval()d, yields an Array with the
|
|
942
|
-
/// CallArguments as well as the function to run. The generated array is
|
|
943
|
-
///
|
|
944
|
-
/// [JsThis, P0, P1, P2, P3, Pn, F]
|
|
945
|
-
///
|
|
946
|
-
/// where:
|
|
947
|
-
/// * F is the functionDeclaration in the request
|
|
948
|
-
/// * JsThis is either:
|
|
949
|
-
/// * undefined (if the request has an object ID); or
|
|
950
|
-
/// * the placeholder kJsThisArgPlaceholder
|
|
951
|
-
/// * Pi is either:
|
|
952
|
-
/// * the string in CallArgument[i].unserializableValue; or
|
|
953
|
-
/// * the string in CallArgument[i].value; or
|
|
954
|
-
/// * arguments[j] (i.e., the j-th argument passed to the newly built
|
|
955
|
-
/// function), j being the j-th CallArgument with an ObjectId. This is
|
|
956
|
-
/// needed because there's no easy way to express the objects referred
|
|
957
|
-
/// to by object ids by name.
|
|
958
|
-
class CallFunctionOnBuilder {
|
|
959
|
-
public:
|
|
960
|
-
explicit CallFunctionOnBuilder(const m::runtime::CallFunctionOnRequest &req)
|
|
961
|
-
: executionContextId_(req.executionContextId) {
|
|
962
|
-
out_ << "[";
|
|
963
|
-
thisAndArguments_.emplace_back(CallFunctionOnArgument(req.objectId));
|
|
964
|
-
if (req.objectId) {
|
|
965
|
-
out_ << "undefined, ";
|
|
966
|
-
} else {
|
|
967
|
-
out_ << '\'' << CallFunctionOnRunner::kJsThisArgPlaceholder << "', ";
|
|
968
|
-
}
|
|
969
|
-
|
|
970
|
-
addParams(req.arguments);
|
|
971
|
-
out_ << req.functionDeclaration;
|
|
972
|
-
out_ << "]";
|
|
973
|
-
};
|
|
974
|
-
|
|
975
|
-
/// Extracts the functions that handles the CallFunctionOn requests, as well
|
|
976
|
-
/// as the list of object ids that must be passed when calling it.
|
|
977
|
-
std::pair<std::string, CallFunctionOnRunner> expressionAndRunner() && {
|
|
978
|
-
return std::make_pair(
|
|
979
|
-
std::move(out_).str(),
|
|
980
|
-
CallFunctionOnRunner(
|
|
981
|
-
std::move(thisAndArguments_), std::move(executionContextId_)));
|
|
982
|
-
}
|
|
983
|
-
|
|
984
|
-
private:
|
|
985
|
-
void addParams(const std::optional<std::vector<m::runtime::CallArgument>>
|
|
986
|
-
&maybeArguments) {
|
|
987
|
-
if (maybeArguments) {
|
|
988
|
-
for (const auto &ca : *maybeArguments) {
|
|
989
|
-
addParam(ca);
|
|
990
|
-
thisAndArguments_.emplace_back(CallFunctionOnArgument(ca.objectId));
|
|
991
|
-
out_ << ", ";
|
|
992
|
-
}
|
|
993
|
-
}
|
|
994
|
-
}
|
|
995
|
-
|
|
996
|
-
void addParam(const m::runtime::CallArgument &ca) {
|
|
997
|
-
if (ca.objectId) {
|
|
998
|
-
out_ << "undefined";
|
|
999
|
-
} else if (ca.value) {
|
|
1000
|
-
// TODO: this may throw if ca.value is a CBOR (see RFC 8949), but the
|
|
1001
|
-
// chrome debugger doesn't seem to send those.
|
|
1002
|
-
out_ << "(" << folly::toJson(*ca.value) << ")";
|
|
1003
|
-
} else if (ca.unserializableValue) {
|
|
1004
|
-
if (unserializableValueLooksLikeNumber(*ca.unserializableValue)) {
|
|
1005
|
-
out_ << "+(" << *ca.unserializableValue << ")";
|
|
1006
|
-
} else {
|
|
1007
|
-
out_ << *ca.unserializableValue;
|
|
1008
|
-
}
|
|
1009
|
-
} else {
|
|
1010
|
-
throw std::runtime_error("unknown payload for CallParam");
|
|
1011
|
-
}
|
|
1012
|
-
}
|
|
1013
|
-
|
|
1014
|
-
std::ostringstream out_;
|
|
1015
|
-
|
|
1016
|
-
std::vector<CallFunctionOnArgument> thisAndArguments_;
|
|
1017
|
-
std::optional<m::runtime::ExecutionContextId> executionContextId_;
|
|
1018
|
-
};
|
|
1019
|
-
|
|
1020
|
-
} // namespace
|
|
1021
|
-
|
|
1022
|
-
void Connection::Impl::handle(const m::runtime::CallFunctionOnRequest &req) {
|
|
1023
|
-
std::string expression;
|
|
1024
|
-
CallFunctionOnRunner runner;
|
|
1025
|
-
|
|
1026
|
-
auto validateAndParseRequest =
|
|
1027
|
-
[&expression, &runner](const m::runtime::CallFunctionOnRequest &req)
|
|
1028
|
-
-> std::optional<std::string> {
|
|
1029
|
-
if (req.objectId.has_value() == req.executionContextId.has_value()) {
|
|
1030
|
-
return std::string(
|
|
1031
|
-
"The request must specify either object id or execution context id.");
|
|
1032
|
-
}
|
|
1033
|
-
|
|
1034
|
-
if (!req.objectId) {
|
|
1035
|
-
assert(
|
|
1036
|
-
req.executionContextId &&
|
|
1037
|
-
"should not be here if both object id and execution context id are missing");
|
|
1038
|
-
if (*req.executionContextId != kHermesExecutionContextId) {
|
|
1039
|
-
return "unknown execution context id " +
|
|
1040
|
-
std::to_string(*req.executionContextId);
|
|
1041
|
-
}
|
|
1042
|
-
}
|
|
1043
|
-
|
|
1044
|
-
try {
|
|
1045
|
-
std::tie(expression, runner) =
|
|
1046
|
-
CallFunctionOnBuilder(req).expressionAndRunner();
|
|
1047
|
-
} catch (const std::exception &e) {
|
|
1048
|
-
return std::string(e.what());
|
|
1049
|
-
}
|
|
1050
|
-
|
|
1051
|
-
return {};
|
|
1052
|
-
};
|
|
1053
|
-
|
|
1054
|
-
if (auto errMsg = validateAndParseRequest(req)) {
|
|
1055
|
-
sendErrorToClientViaExecutor(req.id, *errMsg);
|
|
1056
|
-
return;
|
|
1057
|
-
}
|
|
1058
|
-
|
|
1059
|
-
auto remoteObjPtr = std::make_shared<m::runtime::RemoteObject>();
|
|
1060
|
-
inspector_
|
|
1061
|
-
->evaluate(
|
|
1062
|
-
0, // Top of the stackframe
|
|
1063
|
-
expression,
|
|
1064
|
-
[this,
|
|
1065
|
-
remoteObjPtr,
|
|
1066
|
-
objectGroup = req.objectGroup,
|
|
1067
|
-
jsThisId = req.objectId,
|
|
1068
|
-
byValue = req.returnByValue.value_or(false),
|
|
1069
|
-
generatePreview = req.generatePreview.value_or(false),
|
|
1070
|
-
runner =
|
|
1071
|
-
std::move(runner)](const facebook::hermes::debugger::EvalResult
|
|
1072
|
-
&evalResult) mutable {
|
|
1073
|
-
if (evalResult.isException) {
|
|
1074
|
-
return;
|
|
1075
|
-
}
|
|
1076
|
-
|
|
1077
|
-
*remoteObjPtr = m::runtime::makeRemoteObject(
|
|
1078
|
-
getRuntime(),
|
|
1079
|
-
runner(getRuntime(), objTable_, evalResult),
|
|
1080
|
-
objTable_,
|
|
1081
|
-
objectGroup.value_or("ConsoleObjectGroup"),
|
|
1082
|
-
byValue,
|
|
1083
|
-
generatePreview);
|
|
1084
|
-
})
|
|
1085
|
-
.via(executor_.get())
|
|
1086
|
-
.thenValue(
|
|
1087
|
-
[this, id = req.id, remoteObjPtr](debugger::EvalResult result) {
|
|
1088
|
-
m::debugger::EvaluateOnCallFrameResponse resp;
|
|
1089
|
-
resp.id = id;
|
|
1090
|
-
|
|
1091
|
-
if (result.isException) {
|
|
1092
|
-
resp.exceptionDetails =
|
|
1093
|
-
m::runtime::makeExceptionDetails(result.exceptionDetails);
|
|
1094
|
-
} else {
|
|
1095
|
-
resp.result = std::move(*remoteObjPtr);
|
|
1096
|
-
}
|
|
1097
|
-
|
|
1098
|
-
sendResponseToClient(resp);
|
|
1099
|
-
})
|
|
1100
|
-
.thenError<std::exception>(sendErrorToClient(req.id));
|
|
1101
|
-
}
|
|
1102
|
-
|
|
1103
|
-
void Connection::Impl::handle(const m::runtime::CompileScriptRequest &req) {
|
|
1104
|
-
auto resp = std::make_shared<m::runtime::CompileScriptResponse>();
|
|
1105
|
-
resp->id = req.id;
|
|
1106
|
-
|
|
1107
|
-
inspector_
|
|
1108
|
-
->executeIfEnabled(
|
|
1109
|
-
"Runtime.compileScriptRequest",
|
|
1110
|
-
[this, req, resp](const debugger::ProgramState &state) {
|
|
1111
|
-
if (req.executionContextId.has_value() &&
|
|
1112
|
-
req.executionContextId.value() != kHermesExecutionContextId) {
|
|
1113
|
-
throw std::invalid_argument("Invalid execution context");
|
|
1114
|
-
}
|
|
1115
|
-
|
|
1116
|
-
auto source = std::make_shared<jsi::StringBuffer>(req.expression);
|
|
1117
|
-
std::shared_ptr<const jsi::PreparedJavaScript> preparedScript;
|
|
1118
|
-
try {
|
|
1119
|
-
preparedScript =
|
|
1120
|
-
getRuntime().prepareJavaScript(source, req.sourceURL);
|
|
1121
|
-
} catch (const facebook::jsi::JSIException &err) {
|
|
1122
|
-
resp->exceptionDetails = m::runtime::ExceptionDetails();
|
|
1123
|
-
resp->exceptionDetails->text = err.what();
|
|
1124
|
-
return;
|
|
1125
|
-
}
|
|
1126
|
-
|
|
1127
|
-
if (req.persistScript) {
|
|
1128
|
-
auto scriptId = folly::to<std::string>(
|
|
1129
|
-
kUserEnteredScriptPrefix, preparedScripts_.size());
|
|
1130
|
-
preparedScripts_.push_back(std::move(preparedScript));
|
|
1131
|
-
resp->scriptId = scriptId;
|
|
1132
|
-
}
|
|
1133
|
-
})
|
|
1134
|
-
.via(executor_.get())
|
|
1135
|
-
.thenValue([this, resp](auto &&) { sendResponseToClient(*resp); })
|
|
1136
|
-
.thenError<std::exception>(sendErrorToClient(req.id));
|
|
1137
|
-
}
|
|
1138
|
-
|
|
1139
|
-
void Connection::Impl::handle(const m::runtime::EvaluateRequest &req) {
|
|
1140
|
-
auto remoteObjPtr = std::make_shared<m::runtime::RemoteObject>();
|
|
1141
|
-
|
|
1142
|
-
inspector_
|
|
1143
|
-
->evaluate(
|
|
1144
|
-
0, // Top of the stackframe
|
|
1145
|
-
req.expression,
|
|
1146
|
-
[this,
|
|
1147
|
-
remoteObjPtr,
|
|
1148
|
-
objectGroup = req.objectGroup,
|
|
1149
|
-
byValue = req.returnByValue.value_or(false),
|
|
1150
|
-
generatePreview = req.generatePreview.value_or(false)](
|
|
1151
|
-
const facebook::hermes::debugger::EvalResult
|
|
1152
|
-
&evalResult) mutable {
|
|
1153
|
-
*remoteObjPtr = m::runtime::makeRemoteObject(
|
|
1154
|
-
getRuntime(),
|
|
1155
|
-
evalResult.value,
|
|
1156
|
-
objTable_,
|
|
1157
|
-
objectGroup.value_or("ConsoleObjectGroup"),
|
|
1158
|
-
byValue,
|
|
1159
|
-
generatePreview);
|
|
1160
|
-
})
|
|
1161
|
-
.via(executor_.get())
|
|
1162
|
-
.thenValue(
|
|
1163
|
-
[this, id = req.id, remoteObjPtr](debugger::EvalResult result) {
|
|
1164
|
-
m::debugger::EvaluateOnCallFrameResponse resp;
|
|
1165
|
-
resp.id = id;
|
|
1166
|
-
|
|
1167
|
-
if (result.isException) {
|
|
1168
|
-
resp.exceptionDetails =
|
|
1169
|
-
m::runtime::makeExceptionDetails(result.exceptionDetails);
|
|
1170
|
-
} else {
|
|
1171
|
-
resp.result = std::move(*remoteObjPtr);
|
|
1172
|
-
}
|
|
1173
|
-
|
|
1174
|
-
sendResponseToClient(resp);
|
|
1175
|
-
})
|
|
1176
|
-
.thenError<std::exception>(sendErrorToClient(req.id));
|
|
1177
|
-
}
|
|
1178
|
-
|
|
1179
|
-
void Connection::Impl::handle(const m::debugger::PauseRequest &req) {
|
|
1180
|
-
sendResponseToClientViaExecutor(inspector_->pause(), req.id);
|
|
1181
|
-
}
|
|
1182
|
-
|
|
1183
|
-
void Connection::Impl::handle(const m::debugger::RemoveBreakpointRequest &req) {
|
|
1184
|
-
if (isVirtualBreakpointId(req.breakpointId)) {
|
|
1185
|
-
std::scoped_lock lock(virtualBreakpointMutex_);
|
|
1186
|
-
if (!removeVirtualBreakpoint(req.breakpointId)) {
|
|
1187
|
-
sendErrorToClientViaExecutor(
|
|
1188
|
-
req.id, "Unknown breakpoint ID: " + req.breakpointId);
|
|
1189
|
-
}
|
|
1190
|
-
sendResponseToClientViaExecutor(req.id);
|
|
1191
|
-
} else {
|
|
1192
|
-
auto breakpointId = folly::to<debugger::BreakpointID>(req.breakpointId);
|
|
1193
|
-
sendResponseToClientViaExecutor(
|
|
1194
|
-
inspector_->removeBreakpoint(breakpointId), req.id);
|
|
1195
|
-
}
|
|
1196
|
-
}
|
|
1197
|
-
|
|
1198
|
-
void Connection::Impl::handle(const m::debugger::ResumeRequest &req) {
|
|
1199
|
-
sendResponseToClientViaExecutor(inspector_->resume(), req.id);
|
|
1200
|
-
}
|
|
1201
|
-
|
|
1202
|
-
void Connection::Impl::handle(const m::debugger::SetBreakpointRequest &req) {
|
|
1203
|
-
debugger::SourceLocation loc;
|
|
1204
|
-
|
|
1205
|
-
auto scriptId = folly::tryTo<unsigned int>(req.location.scriptId);
|
|
1206
|
-
if (!scriptId) {
|
|
1207
|
-
sendErrorToClientViaExecutor(
|
|
1208
|
-
req.id, "Expected integer scriptId: " + req.location.scriptId);
|
|
1209
|
-
return;
|
|
1210
|
-
}
|
|
1211
|
-
|
|
1212
|
-
loc.fileId = scriptId.value();
|
|
1213
|
-
// CDP Locations are 0-based, Hermes lines/columns are 1-based
|
|
1214
|
-
loc.line = req.location.lineNumber + 1;
|
|
1215
|
-
if (req.location.columnNumber) {
|
|
1216
|
-
loc.column = req.location.columnNumber.value() + 1;
|
|
1217
|
-
}
|
|
1218
|
-
|
|
1219
|
-
inspector_->setBreakpoint(loc, req.condition)
|
|
1220
|
-
.via(executor_.get())
|
|
1221
|
-
.thenValue([this, id = req.id](debugger::BreakpointInfo info) {
|
|
1222
|
-
m::debugger::SetBreakpointResponse resp;
|
|
1223
|
-
resp.id = id;
|
|
1224
|
-
resp.breakpointId = folly::to<std::string>(info.id);
|
|
1225
|
-
|
|
1226
|
-
if (info.resolved) {
|
|
1227
|
-
resp.actualLocation =
|
|
1228
|
-
m::debugger::makeLocation(info.resolvedLocation);
|
|
1229
|
-
}
|
|
1230
|
-
|
|
1231
|
-
sendResponseToClient(resp);
|
|
1232
|
-
})
|
|
1233
|
-
.thenError<std::exception>(sendErrorToClient(req.id));
|
|
1234
|
-
}
|
|
1235
|
-
|
|
1236
|
-
void Connection::Impl::handle(
|
|
1237
|
-
const m::debugger::SetBreakpointByUrlRequest &req) {
|
|
1238
|
-
debugger::SourceLocation loc;
|
|
1239
|
-
|
|
1240
|
-
{
|
|
1241
|
-
std::scoped_lock lock(parsedScriptsMutex_);
|
|
1242
|
-
setHermesLocation(loc, req, parsedScripts_);
|
|
1243
|
-
}
|
|
1244
|
-
|
|
1245
|
-
inspector_->setBreakpoint(loc, req.condition)
|
|
1246
|
-
.via(executor_.get())
|
|
1247
|
-
.thenValue([this, id = req.id](debugger::BreakpointInfo info) {
|
|
1248
|
-
m::debugger::SetBreakpointByUrlResponse resp;
|
|
1249
|
-
resp.id = id;
|
|
1250
|
-
resp.breakpointId = folly::to<std::string>(info.id);
|
|
1251
|
-
|
|
1252
|
-
if (info.resolved) {
|
|
1253
|
-
resp.locations.emplace_back(
|
|
1254
|
-
m::debugger::makeLocation(info.resolvedLocation));
|
|
1255
|
-
}
|
|
1256
|
-
|
|
1257
|
-
sendResponseToClient(resp);
|
|
1258
|
-
})
|
|
1259
|
-
.thenError<std::exception>(sendErrorToClient(req.id));
|
|
1260
|
-
}
|
|
1261
|
-
|
|
1262
|
-
void Connection::Impl::handle(
|
|
1263
|
-
const m::debugger::SetBreakpointsActiveRequest &req) {
|
|
1264
|
-
inspector_->setBreakpointsActive(req.active)
|
|
1265
|
-
.via(executor_.get())
|
|
1266
|
-
.thenValue([this, id = req.id](const Unit &unit) {
|
|
1267
|
-
sendResponseToClient(m::makeOkResponse(id));
|
|
1268
|
-
})
|
|
1269
|
-
.thenError<std::exception>(sendErrorToClient(req.id));
|
|
1270
|
-
}
|
|
1271
|
-
|
|
1272
|
-
bool Connection::Impl::isVirtualBreakpointId(const std::string &id) {
|
|
1273
|
-
return id.rfind(kVirtualBreakpointPrefix, 0) == 0;
|
|
1274
|
-
}
|
|
1275
|
-
|
|
1276
|
-
const std::string &Connection::Impl::createVirtualBreakpoint(
|
|
1277
|
-
const std::string &category) {
|
|
1278
|
-
auto ret = virtualBreakpoints_[category].insert(folly::to<std::string>(
|
|
1279
|
-
kVirtualBreakpointPrefix, nextVirtualBreakpoint_++));
|
|
1280
|
-
return *ret.first;
|
|
1281
|
-
}
|
|
1282
|
-
|
|
1283
|
-
bool Connection::Impl::hasVirtualBreakpoint(const std::string &category) {
|
|
1284
|
-
auto pos = virtualBreakpoints_.find(category);
|
|
1285
|
-
if (pos == virtualBreakpoints_.end())
|
|
1286
|
-
return false;
|
|
1287
|
-
return !pos->second.empty();
|
|
1288
|
-
}
|
|
1289
|
-
|
|
1290
|
-
bool Connection::Impl::removeVirtualBreakpoint(const std::string &id) {
|
|
1291
|
-
// We expect roughly 1 category, so just iterate over all the sets
|
|
1292
|
-
for (auto &kv : virtualBreakpoints_) {
|
|
1293
|
-
if (kv.second.erase(id) > 0) {
|
|
1294
|
-
return true;
|
|
1295
|
-
}
|
|
1296
|
-
}
|
|
1297
|
-
return false;
|
|
1298
|
-
}
|
|
1299
|
-
|
|
1300
|
-
void Connection::Impl::handle(
|
|
1301
|
-
const m::debugger::SetInstrumentationBreakpointRequest &req) {
|
|
1302
|
-
if (req.instrumentation != kBeforeScriptWithSourceMapExecution) {
|
|
1303
|
-
sendErrorToClientViaExecutor(
|
|
1304
|
-
req.id, "Unknown instrumentation breakpoint: " + req.instrumentation);
|
|
1305
|
-
return;
|
|
1306
|
-
}
|
|
1307
|
-
|
|
1308
|
-
// The act of creating and registering the breakpoint ID is enough
|
|
1309
|
-
// to "set" it. We merely check for the existence of them later.
|
|
1310
|
-
std::scoped_lock lock(virtualBreakpointMutex_);
|
|
1311
|
-
m::debugger::SetInstrumentationBreakpointResponse resp;
|
|
1312
|
-
resp.id = req.id;
|
|
1313
|
-
resp.breakpointId = createVirtualBreakpoint(req.instrumentation);
|
|
1314
|
-
sendResponseToClientViaExecutor(resp);
|
|
1315
|
-
}
|
|
1316
|
-
|
|
1317
|
-
void Connection::Impl::handle(
|
|
1318
|
-
const m::debugger::SetPauseOnExceptionsRequest &req) {
|
|
1319
|
-
debugger::PauseOnThrowMode mode = debugger::PauseOnThrowMode::None;
|
|
1320
|
-
|
|
1321
|
-
if (req.state == "none") {
|
|
1322
|
-
mode = debugger::PauseOnThrowMode::None;
|
|
1323
|
-
} else if (req.state == "all") {
|
|
1324
|
-
mode = debugger::PauseOnThrowMode::All;
|
|
1325
|
-
} else if (req.state == "uncaught") {
|
|
1326
|
-
mode = debugger::PauseOnThrowMode::Uncaught;
|
|
1327
|
-
} else {
|
|
1328
|
-
sendErrorToClientViaExecutor(
|
|
1329
|
-
req.id, "Unknown pause-on-exception state: " + req.state);
|
|
1330
|
-
return;
|
|
1331
|
-
}
|
|
1332
|
-
|
|
1333
|
-
sendResponseToClientViaExecutor(
|
|
1334
|
-
inspector_->setPauseOnExceptions(mode), req.id);
|
|
1335
|
-
}
|
|
1336
|
-
|
|
1337
|
-
void Connection::Impl::handle(const m::debugger::StepIntoRequest &req) {
|
|
1338
|
-
sendResponseToClientViaExecutor(inspector_->stepIn(), req.id);
|
|
1339
|
-
}
|
|
1340
|
-
|
|
1341
|
-
void Connection::Impl::handle(const m::debugger::StepOutRequest &req) {
|
|
1342
|
-
sendResponseToClientViaExecutor(inspector_->stepOut(), req.id);
|
|
1343
|
-
}
|
|
1344
|
-
|
|
1345
|
-
void Connection::Impl::handle(const m::debugger::StepOverRequest &req) {
|
|
1346
|
-
sendResponseToClientViaExecutor(inspector_->stepOver(), req.id);
|
|
1347
|
-
}
|
|
1348
|
-
|
|
1349
|
-
std::vector<m::runtime::PropertyDescriptor>
|
|
1350
|
-
Connection::Impl::makePropsFromScope(
|
|
1351
|
-
std::pair<uint32_t, uint32_t> frameAndScopeIndex,
|
|
1352
|
-
const std::string &objectGroup,
|
|
1353
|
-
const debugger::ProgramState &state,
|
|
1354
|
-
bool generatePreview) {
|
|
1355
|
-
// Chrome represents variables in a scope as properties on a dummy object.
|
|
1356
|
-
// We don't instantiate such dummy objects, we just pretended to have one.
|
|
1357
|
-
// Chrome has now asked for its properties, so it's time to synthesize
|
|
1358
|
-
// descriptions of the properties that the dummy object would have had.
|
|
1359
|
-
std::vector<m::runtime::PropertyDescriptor> result;
|
|
1360
|
-
|
|
1361
|
-
uint32_t frameIndex = frameAndScopeIndex.first;
|
|
1362
|
-
uint32_t scopeIndex = frameAndScopeIndex.second;
|
|
1363
|
-
debugger::LexicalInfo lexicalInfo = state.getLexicalInfo(frameIndex);
|
|
1364
|
-
uint32_t varCount = lexicalInfo.getVariablesCountInScope(scopeIndex);
|
|
1365
|
-
|
|
1366
|
-
// If this is the frame's local scope, include 'this'.
|
|
1367
|
-
if (scopeIndex == 0) {
|
|
1368
|
-
auto varInfo = state.getVariableInfoForThis(frameIndex);
|
|
1369
|
-
m::runtime::PropertyDescriptor desc;
|
|
1370
|
-
desc.name = varInfo.name;
|
|
1371
|
-
desc.value = m::runtime::makeRemoteObject(
|
|
1372
|
-
getRuntime(),
|
|
1373
|
-
varInfo.value,
|
|
1374
|
-
objTable_,
|
|
1375
|
-
objectGroup,
|
|
1376
|
-
false,
|
|
1377
|
-
generatePreview);
|
|
1378
|
-
// Chrome only shows enumerable properties.
|
|
1379
|
-
desc.enumerable = true;
|
|
1380
|
-
result.emplace_back(std::move(desc));
|
|
1381
|
-
}
|
|
1382
|
-
|
|
1383
|
-
// Then add each of the variables in this lexical scope.
|
|
1384
|
-
for (uint32_t varIndex = 0; varIndex < varCount; varIndex++) {
|
|
1385
|
-
debugger::VariableInfo varInfo =
|
|
1386
|
-
state.getVariableInfo(frameIndex, scopeIndex, varIndex);
|
|
1387
|
-
|
|
1388
|
-
m::runtime::PropertyDescriptor desc;
|
|
1389
|
-
desc.name = varInfo.name;
|
|
1390
|
-
desc.value = m::runtime::makeRemoteObject(
|
|
1391
|
-
getRuntime(),
|
|
1392
|
-
varInfo.value,
|
|
1393
|
-
objTable_,
|
|
1394
|
-
objectGroup,
|
|
1395
|
-
false,
|
|
1396
|
-
generatePreview);
|
|
1397
|
-
desc.enumerable = true;
|
|
1398
|
-
|
|
1399
|
-
result.emplace_back(std::move(desc));
|
|
1400
|
-
}
|
|
1401
|
-
|
|
1402
|
-
return result;
|
|
1403
|
-
}
|
|
1404
|
-
|
|
1405
|
-
std::vector<m::runtime::PropertyDescriptor>
|
|
1406
|
-
Connection::Impl::makePropsFromValue(
|
|
1407
|
-
const jsi::Value &value,
|
|
1408
|
-
const std::string &objectGroup,
|
|
1409
|
-
bool onlyOwnProperties,
|
|
1410
|
-
bool generatePreview) {
|
|
1411
|
-
std::vector<m::runtime::PropertyDescriptor> result;
|
|
1412
|
-
|
|
1413
|
-
if (value.isObject()) {
|
|
1414
|
-
jsi::Runtime &runtime = getRuntime();
|
|
1415
|
-
jsi::Object obj = value.getObject(runtime);
|
|
1416
|
-
|
|
1417
|
-
// TODO(hypuk): obj.getPropertyNames only returns enumerable properties.
|
|
1418
|
-
jsi::Array propNames = onlyOwnProperties
|
|
1419
|
-
? runtime.global()
|
|
1420
|
-
.getPropertyAsObject(runtime, "Object")
|
|
1421
|
-
.getPropertyAsFunction(runtime, "getOwnPropertyNames")
|
|
1422
|
-
.call(runtime, obj)
|
|
1423
|
-
.getObject(runtime)
|
|
1424
|
-
.getArray(runtime)
|
|
1425
|
-
: obj.getPropertyNames(runtime);
|
|
1426
|
-
|
|
1427
|
-
size_t propCount = propNames.length(runtime);
|
|
1428
|
-
for (size_t i = 0; i < propCount; i++) {
|
|
1429
|
-
jsi::String propName =
|
|
1430
|
-
propNames.getValueAtIndex(runtime, i).getString(runtime);
|
|
1431
|
-
|
|
1432
|
-
m::runtime::PropertyDescriptor desc;
|
|
1433
|
-
desc.name = propName.utf8(runtime);
|
|
1434
|
-
|
|
1435
|
-
try {
|
|
1436
|
-
// Currently, we fetch the property even if it runs code.
|
|
1437
|
-
// Chrome instead detects getters and makes you click to invoke.
|
|
1438
|
-
jsi::Value propValue = obj.getProperty(runtime, propName);
|
|
1439
|
-
desc.value = m::runtime::makeRemoteObject(
|
|
1440
|
-
runtime, propValue, objTable_, objectGroup, false, generatePreview);
|
|
1441
|
-
} catch (const jsi::JSError &err) {
|
|
1442
|
-
// We fetched a property with a getter that threw. Show a placeholder.
|
|
1443
|
-
// We could have added additional info, but the UI quickly gets messy.
|
|
1444
|
-
desc.value = m::runtime::makeRemoteObject(
|
|
1445
|
-
runtime,
|
|
1446
|
-
jsi::String::createFromUtf8(runtime, "(Exception)"),
|
|
1447
|
-
objTable_,
|
|
1448
|
-
objectGroup,
|
|
1449
|
-
false,
|
|
1450
|
-
generatePreview);
|
|
1451
|
-
}
|
|
1452
|
-
|
|
1453
|
-
result.emplace_back(std::move(desc));
|
|
1454
|
-
}
|
|
1455
|
-
|
|
1456
|
-
if (onlyOwnProperties) {
|
|
1457
|
-
jsi::Value proto = runtime.global()
|
|
1458
|
-
.getPropertyAsObject(runtime, "Object")
|
|
1459
|
-
.getPropertyAsFunction(runtime, "getPrototypeOf")
|
|
1460
|
-
.call(runtime, obj);
|
|
1461
|
-
if (!proto.isNull()) {
|
|
1462
|
-
m::runtime::PropertyDescriptor desc;
|
|
1463
|
-
desc.name = "__proto__";
|
|
1464
|
-
desc.value = m::runtime::makeRemoteObject(
|
|
1465
|
-
runtime, proto, objTable_, objectGroup, false, generatePreview);
|
|
1466
|
-
result.emplace_back(std::move(desc));
|
|
1467
|
-
}
|
|
1468
|
-
}
|
|
1469
|
-
}
|
|
1470
|
-
|
|
1471
|
-
return result;
|
|
1472
|
-
}
|
|
1473
|
-
|
|
1474
|
-
void Connection::Impl::handle(const m::runtime::GetHeapUsageRequest &req) {
|
|
1475
|
-
runInExecutor(req.id, [this, req]() {
|
|
1476
|
-
auto heapInfo = getRuntime().instrumentation().getHeapInfo(false);
|
|
1477
|
-
auto resp = std::make_shared<m::runtime::GetHeapUsageResponse>();
|
|
1478
|
-
resp->id = req.id;
|
|
1479
|
-
resp->usedSize = heapInfo["hermes_allocatedBytes"];
|
|
1480
|
-
resp->totalSize = heapInfo["hermes_heapSize"];
|
|
1481
|
-
sendResponseToClient(*resp);
|
|
1482
|
-
});
|
|
1483
|
-
}
|
|
1484
|
-
|
|
1485
|
-
void Connection::Impl::handle(const m::runtime::GetPropertiesRequest &req) {
|
|
1486
|
-
auto resp = std::make_shared<m::runtime::GetPropertiesResponse>();
|
|
1487
|
-
resp->id = req.id;
|
|
1488
|
-
|
|
1489
|
-
inspector_
|
|
1490
|
-
->executeIfEnabled(
|
|
1491
|
-
"Runtime.getProperties",
|
|
1492
|
-
[this,
|
|
1493
|
-
req,
|
|
1494
|
-
resp,
|
|
1495
|
-
generatePreview = req.generatePreview.value_or(false)](
|
|
1496
|
-
const debugger::ProgramState &state) {
|
|
1497
|
-
std::string objGroup = objTable_.getObjectGroup(req.objectId);
|
|
1498
|
-
auto scopePtr = objTable_.getScope(req.objectId);
|
|
1499
|
-
auto valuePtr = objTable_.getValue(req.objectId);
|
|
1500
|
-
|
|
1501
|
-
if (scopePtr != nullptr) {
|
|
1502
|
-
resp->result = makePropsFromScope(
|
|
1503
|
-
*scopePtr, objGroup, state, generatePreview);
|
|
1504
|
-
} else if (valuePtr != nullptr) {
|
|
1505
|
-
resp->result = makePropsFromValue(
|
|
1506
|
-
*valuePtr,
|
|
1507
|
-
objGroup,
|
|
1508
|
-
req.ownProperties.value_or(true),
|
|
1509
|
-
generatePreview);
|
|
1510
|
-
}
|
|
1511
|
-
})
|
|
1512
|
-
.via(executor_.get())
|
|
1513
|
-
.thenValue([this, resp](auto &&) { sendResponseToClient(*resp); })
|
|
1514
|
-
.thenError<std::exception>(sendErrorToClient(req.id));
|
|
1515
|
-
}
|
|
1516
|
-
|
|
1517
|
-
void Connection::Impl::handle(
|
|
1518
|
-
const m::runtime::GlobalLexicalScopeNamesRequest &req) {
|
|
1519
|
-
auto resp = std::make_shared<m::runtime::GlobalLexicalScopeNamesResponse>();
|
|
1520
|
-
resp->id = req.id;
|
|
1521
|
-
|
|
1522
|
-
inspector_
|
|
1523
|
-
->executeIfEnabled(
|
|
1524
|
-
"Runtime.globalLexicalScopeNames",
|
|
1525
|
-
[req, resp](const debugger::ProgramState &state) {
|
|
1526
|
-
if (req.executionContextId.has_value() &&
|
|
1527
|
-
req.executionContextId.value() != kHermesExecutionContextId) {
|
|
1528
|
-
throw std::invalid_argument("Invalid execution context");
|
|
1529
|
-
}
|
|
1530
|
-
|
|
1531
|
-
const debugger::LexicalInfo &lexicalInfo = state.getLexicalInfo(0);
|
|
1532
|
-
debugger::ScopeDepth scopeCount = lexicalInfo.getScopesCount();
|
|
1533
|
-
if (scopeCount == 0) {
|
|
1534
|
-
return;
|
|
1535
|
-
}
|
|
1536
|
-
|
|
1537
|
-
const debugger::ScopeDepth globalScopeIndex = scopeCount - 1;
|
|
1538
|
-
uint32_t variableCount =
|
|
1539
|
-
lexicalInfo.getVariablesCountInScope(globalScopeIndex);
|
|
1540
|
-
resp->names.reserve(variableCount);
|
|
1541
|
-
for (uint32_t i = 0; i < variableCount; i++) {
|
|
1542
|
-
debugger::String name =
|
|
1543
|
-
state.getVariableInfo(0, globalScopeIndex, i).name;
|
|
1544
|
-
// The global scope has some entries prefixed with '?', which are
|
|
1545
|
-
// not valid identifiers.
|
|
1546
|
-
if (!name.empty() && name.front() != '?') {
|
|
1547
|
-
resp->names.push_back(name);
|
|
1548
|
-
}
|
|
1549
|
-
}
|
|
1550
|
-
})
|
|
1551
|
-
.via(executor_.get())
|
|
1552
|
-
.thenValue([this, resp](auto &&) { sendResponseToClient(*resp); })
|
|
1553
|
-
.thenError<std::exception>(sendErrorToClient(req.id));
|
|
1554
|
-
}
|
|
1555
|
-
|
|
1556
|
-
void Connection::Impl::handle(
|
|
1557
|
-
const m::runtime::RunIfWaitingForDebuggerRequest &req) {
|
|
1558
|
-
if (inspector_->isAwaitingDebuggerOnStart()) {
|
|
1559
|
-
sendResponseToClientViaExecutor(inspector_->resume(), req.id);
|
|
1560
|
-
} else {
|
|
1561
|
-
// We weren't awaiting a debugger. Just send an 'ok'.
|
|
1562
|
-
sendResponseToClientViaExecutor(req.id);
|
|
1563
|
-
}
|
|
1564
|
-
}
|
|
1565
|
-
|
|
1566
|
-
/*
|
|
1567
|
-
* Send-to-client methods
|
|
1568
|
-
*/
|
|
1569
|
-
|
|
1570
|
-
void Connection::Impl::sendToClient(const std::string &str) {
|
|
1571
|
-
if (remoteConn_) {
|
|
1572
|
-
remoteConn_->onMessage(str);
|
|
1573
|
-
}
|
|
1574
|
-
}
|
|
1575
|
-
|
|
1576
|
-
void Connection::Impl::sendResponseToClient(const m::Response &resp) {
|
|
1577
|
-
sendToClient(resp.toJson());
|
|
1578
|
-
}
|
|
1579
|
-
|
|
1580
|
-
void Connection::Impl::sendNotificationToClient(const m::Notification ¬e) {
|
|
1581
|
-
sendToClient(note.toJson());
|
|
1582
|
-
}
|
|
1583
|
-
|
|
1584
|
-
folly::Function<void(const std::exception &)>
|
|
1585
|
-
Connection::Impl::sendErrorToClient(int id) {
|
|
1586
|
-
return [this, id](const std::exception &e) {
|
|
1587
|
-
sendResponseToClient(
|
|
1588
|
-
m::makeErrorResponse(id, m::ErrorCode::ServerError, e.what()));
|
|
1589
|
-
};
|
|
1590
|
-
}
|
|
1591
|
-
|
|
1592
|
-
void Connection::Impl::sendResponseToClientViaExecutor(int id) {
|
|
1593
|
-
sendResponseToClientViaExecutor(folly::makeFuture(), id);
|
|
1594
|
-
}
|
|
1595
|
-
|
|
1596
|
-
void Connection::Impl::sendResponseToClientViaExecutor(
|
|
1597
|
-
const m::Response &resp) {
|
|
1598
|
-
std::string json = resp.toJson();
|
|
1599
|
-
|
|
1600
|
-
folly::makeFuture()
|
|
1601
|
-
.via(executor_.get())
|
|
1602
|
-
.thenValue([this, json](const Unit &unit) { sendToClient(json); });
|
|
1603
|
-
}
|
|
1604
|
-
|
|
1605
|
-
void Connection::Impl::sendResponseToClientViaExecutor(
|
|
1606
|
-
folly::Future<Unit> future,
|
|
1607
|
-
int id) {
|
|
1608
|
-
future.via(executor_.get())
|
|
1609
|
-
.thenValue([this, id](const Unit &unit) {
|
|
1610
|
-
sendResponseToClient(m::makeOkResponse(id));
|
|
1611
|
-
})
|
|
1612
|
-
.thenError<std::exception>(sendErrorToClient(id));
|
|
1613
|
-
}
|
|
1614
|
-
|
|
1615
|
-
void Connection::Impl::sendErrorToClientViaExecutor(
|
|
1616
|
-
int id,
|
|
1617
|
-
const std::string &error) {
|
|
1618
|
-
folly::makeFuture()
|
|
1619
|
-
.via(executor_.get())
|
|
1620
|
-
.thenValue([this, id, error](const Unit &unit) {
|
|
1621
|
-
sendResponseToClient(
|
|
1622
|
-
makeErrorResponse(id, m::ErrorCode::ServerError, error));
|
|
1623
|
-
});
|
|
1624
|
-
}
|
|
1625
|
-
|
|
1626
|
-
void Connection::Impl::sendNotificationToClientViaExecutor(
|
|
1627
|
-
const m::Notification ¬e) {
|
|
1628
|
-
executor_->add(
|
|
1629
|
-
[this, noteJson = note.toJson()]() { sendToClient(noteJson); });
|
|
1630
|
-
}
|
|
1631
|
-
|
|
1632
|
-
/*
|
|
1633
|
-
* Connection
|
|
1634
|
-
*/
|
|
1635
|
-
Connection::Connection(
|
|
1636
|
-
std::unique_ptr<RuntimeAdapter> adapter,
|
|
1637
|
-
const std::string &title,
|
|
1638
|
-
bool waitForDebugger)
|
|
1639
|
-
: impl_(
|
|
1640
|
-
std::make_unique<Impl>(std::move(adapter), title, waitForDebugger)) {}
|
|
1641
|
-
|
|
1642
|
-
Connection::~Connection() = default;
|
|
1643
|
-
|
|
1644
|
-
HermesRuntime &Connection::getRuntime() {
|
|
1645
|
-
return impl_->getRuntime();
|
|
1646
|
-
}
|
|
1647
|
-
|
|
1648
|
-
std::string Connection::getTitle() const {
|
|
1649
|
-
return impl_->getTitle();
|
|
1650
|
-
}
|
|
1651
|
-
|
|
1652
|
-
bool Connection::connect(std::unique_ptr<IRemoteConnection> remoteConn) {
|
|
1653
|
-
return impl_->connect(std::move(remoteConn));
|
|
1654
|
-
}
|
|
1655
|
-
|
|
1656
|
-
bool Connection::disconnect() {
|
|
1657
|
-
return impl_->disconnect();
|
|
1658
|
-
}
|
|
1659
|
-
|
|
1660
|
-
void Connection::sendMessage(std::string str) {
|
|
1661
|
-
impl_->sendMessage(std::move(str));
|
|
1662
|
-
}
|
|
1663
|
-
|
|
1664
|
-
} // namespace chrome
|
|
1665
|
-
} // namespace inspector_modern
|
|
1666
|
-
} // namespace hermes
|
|
1667
|
-
} // namespace facebook
|