react-native-windows 0.68.3 → 0.69.0-preview.1
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/.flowconfig +1 -3
- package/Chakra/ChakraHelpers.cpp +0 -1
- package/Directory.Build.props +3 -0
- package/Directory.Build.targets +1 -1
- package/Folly/TEMP_UntilFollyUpdate/dynamic-inl.h +1411 -0
- package/Folly/TEMP_UntilFollyUpdate/lang/ToAscii.cpp +336 -0
- package/Folly/TEMP_UntilFollyUpdate/lang/ToAscii.h +182 -0
- package/Libraries/ActionSheetIOS/ActionSheetIOS.js +7 -0
- package/Libraries/ActionSheetIOS/NativeActionSheetManager.js +1 -0
- package/Libraries/Alert/Alert.windows.js +2 -2
- package/Libraries/Animated/AnimatedImplementation.js +1 -1
- package/Libraries/Animated/NativeAnimatedHelper.js +55 -9
- package/Libraries/Animated/NativeAnimatedModule.js +1 -0
- package/Libraries/Animated/NativeAnimatedTurboModule.js +1 -0
- package/Libraries/Animated/animations/TimingAnimation.js +6 -11
- package/Libraries/Animated/createAnimatedComponent.js +2 -2
- package/Libraries/Animated/nodes/AnimatedColor.js +95 -29
- package/Libraries/Animated/nodes/AnimatedInterpolation.js +19 -22
- package/Libraries/Animated/nodes/AnimatedNode.js +2 -2
- package/Libraries/Animated/nodes/AnimatedValue.js +1 -1
- package/Libraries/AppState/AppState.js +1 -1
- package/Libraries/Blob/URL.js +7 -1
- package/Libraries/Components/Button.js +3 -0
- package/Libraries/Components/Button.windows.js +4 -0
- package/Libraries/Components/DatePickerAndroid/NativeDatePickerAndroid.js +5 -0
- package/Libraries/Components/Pressable/Pressable.js +3 -3
- package/Libraries/Components/Pressable/Pressable.windows.js +3 -3
- package/Libraries/Components/ScrollView/AndroidHorizontalScrollViewNativeComponent.js +47 -38
- package/Libraries/Components/ScrollView/ScrollContentViewNativeComponent.js +15 -7
- package/Libraries/Components/ScrollView/ScrollView.js +1 -1
- package/Libraries/Components/ScrollView/ScrollViewNativeComponent.js +16 -3
- package/Libraries/Components/ScrollView/ScrollViewStickyHeader.js +3 -1
- package/Libraries/Components/Slider/Slider.js +0 -2
- package/Libraries/Components/Slider/SliderNativeComponent.js +0 -1
- package/Libraries/Components/StatusBar/StatusBar.js +6 -1
- package/Libraries/Components/Switch/Switch.js +11 -1
- package/Libraries/Components/TextInput/AndroidTextInputNativeComponent.js +114 -109
- package/Libraries/Components/TextInput/RCTMultilineTextInputNativeComponent.js +17 -9
- package/Libraries/Components/TextInput/RCTSingelineTextInputNativeComponent.js +13 -5
- package/Libraries/Components/TextInput/RCTTextInputViewConfig.js +10 -0
- package/Libraries/Components/TextInput/TextInput.js +1 -8
- package/Libraries/Components/TextInput/TextInput.windows.js +4 -9
- package/Libraries/Components/TextInput/TextInputState.js +10 -2
- package/Libraries/Components/TextInput/TextInputState.windows.js +10 -3
- package/Libraries/Components/TextInput/WindowsTextInputNativeComponent.js +1 -1
- package/Libraries/Components/Touchable/TouchableBounce.js +1 -0
- package/Libraries/Components/Touchable/TouchableHighlight.js +1 -0
- package/Libraries/Components/Touchable/TouchableHighlight.windows.js +6 -5
- package/Libraries/Components/Touchable/TouchableNativeFeedback.js +1 -0
- package/Libraries/Components/Touchable/TouchableOpacity.js +7 -1
- package/Libraries/Components/Touchable/TouchableOpacity.windows.js +11 -5
- package/Libraries/Components/Touchable/TouchableWithoutFeedback.js +2 -0
- package/Libraries/Components/Touchable/TouchableWithoutFeedback.windows.js +2 -0
- package/Libraries/Components/View/ReactNativeViewAttributes.js +1 -0
- package/Libraries/Components/View/ReactNativeViewAttributes.windows.js +1 -0
- package/Libraries/Components/View/View.windows.js +33 -1
- package/Libraries/Components/View/ViewNativeComponent.js +68 -8
- package/Libraries/Components/View/ViewPropTypes.js +36 -4
- package/Libraries/Components/View/ViewPropTypes.windows.js +36 -4
- package/Libraries/Core/Devtools/parseHermesStack.js +1 -1
- package/Libraries/Core/ExceptionsManager.js +1 -1
- package/Libraries/Core/RawEventEmitter.js +38 -0
- package/Libraries/Core/ReactNativeVersion.js +2 -2
- package/Libraries/Core/polyfillPromise.js +32 -0
- package/Libraries/Core/setUpReactDevTools.js +3 -2
- package/Libraries/EventEmitter/NativeEventEmitter.js +3 -3
- package/Libraries/EventEmitter/RCTDeviceEventEmitter.js +2 -1
- package/Libraries/EventEmitter/__mocks__/NativeEventEmitter.js +3 -3
- package/Libraries/Events/CustomEvent.js +32 -0
- package/Libraries/Events/EventPolyfill.js +239 -0
- package/Libraries/Image/Image.android.js +0 -6
- package/Libraries/Image/Image.ios.js +0 -6
- package/Libraries/Image/Image.windows.js +2 -8
- package/Libraries/Image/ImageViewNativeComponent.js +18 -3
- package/Libraries/Image/TextInlineImageNativeComponent.js +23 -15
- package/Libraries/Inspector/Inspector.js +2 -4
- package/Libraries/Interaction/BridgeSpyStallHandler.js +4 -3
- package/Libraries/Interaction/InteractionManager.js +1 -12
- package/Libraries/Interaction/TaskQueue.js +5 -4
- package/Libraries/LayoutAnimation/LayoutAnimation.js +13 -0
- package/Libraries/Linking/Linking.js +1 -1
- package/Libraries/Lists/FlatList.js +27 -6
- package/Libraries/Lists/VirtualizedList.js +71 -55
- package/Libraries/Lists/VirtualizedListContext.js +7 -3
- package/Libraries/Lists/VirtualizedSectionList.js +2 -2
- package/Libraries/Lists/__tests__/{FillRateHelper-test.windows.js → FillRateHelper-test.js} +2 -2
- package/Libraries/Lists/__tests__/{FlatList-test.windows.js → FlatList-test.js} +2 -2
- package/Libraries/Lists/__tests__/{SectionList-test.windows.js → SectionList-test.js} +14 -14
- package/Libraries/Lists/__tests__/{VirtualizeUtils-test.windows.js → VirtualizeUtils-test.js} +3 -3
- package/Libraries/Lists/__tests__/{VirtualizedList-test.windows.js → VirtualizedList-test.js} +91 -42
- package/Libraries/Lists/__tests__/{VirtualizedSectionList-test.windows.js → VirtualizedSectionList-test.js} +13 -13
- package/Libraries/LogBox/Data/LogBoxData.js +2 -2
- package/Libraries/LogBox/Data/LogBoxLog.js +1 -1
- package/Libraries/LogBox/Data/LogBoxSymbolication.js +1 -1
- package/Libraries/LogBox/Data/parseLogBoxLog.js +1 -1
- package/Libraries/LogBox/LogBox.js +2 -21
- package/Libraries/LogBox/UI/LogBoxInspectorFooter.js +1 -0
- package/Libraries/LogBox/UI/LogBoxInspectorHeader.js +2 -1
- package/Libraries/NativeComponent/BaseViewConfig.android.js +295 -0
- package/Libraries/NativeComponent/BaseViewConfig.ios.js +333 -0
- package/Libraries/NativeComponent/BaseViewConfig.windows.js +334 -0
- package/Libraries/NativeComponent/NativeComponentRegistry.js +0 -2
- package/Libraries/NativeComponent/PlatformBaseViewConfig.js +24 -0
- package/Libraries/NativeComponent/StaticViewConfigValidator.js +7 -42
- package/Libraries/NativeComponent/ViewConfig.js +4 -4
- package/Libraries/NativeComponent/ViewConfigIgnore.js +54 -0
- package/Libraries/Network/FormData.js +7 -1
- package/Libraries/Pressability/Pressability.js +115 -46
- package/Libraries/Pressability/Pressability.windows.js +190 -74
- package/Libraries/Pressability/PressabilityDebug.js +5 -9
- package/Libraries/PushNotificationIOS/NativePushNotificationManagerIOS.js +1 -0
- package/Libraries/ReactNative/AppContainer.js +1 -1
- package/Libraries/ReactNative/{DummyUIManager.js → BridgelessUIManager.js} +62 -40
- package/Libraries/ReactNative/PaperUIManager.windows.js +5 -5
- package/Libraries/ReactNative/ReactNativeFeatureFlags.js +39 -0
- package/Libraries/ReactNative/UIManager.js +2 -3
- package/Libraries/ReactNative/renderApplication.js +4 -0
- package/Libraries/ReactPrivate/ReactNativePrivateInterface.js +8 -0
- package/Libraries/Renderer/implementations/ReactFabric-dev.js +5908 -4906
- package/Libraries/Renderer/implementations/ReactFabric-prod.js +2100 -1918
- package/Libraries/Renderer/implementations/ReactFabric-profiling.js +2567 -2352
- package/Libraries/Renderer/implementations/ReactNativeRenderer-dev.js +5610 -4844
- package/Libraries/Renderer/implementations/ReactNativeRenderer-prod.js +1710 -1556
- package/Libraries/Renderer/implementations/ReactNativeRenderer-profiling.js +1830 -1639
- package/Libraries/Renderer/shims/ReactNativeTypes.js +2 -1
- package/Libraries/Renderer/shims/ReactNativeViewConfigRegistry.js +2 -1
- package/Libraries/StyleSheet/EdgeInsetsPropType.js +4 -1
- package/Libraries/StyleSheet/StyleSheetTypes.js +59 -66
- package/Libraries/StyleSheet/normalizeColor.js +1 -1
- package/Libraries/StyleSheet/private/_StyleSheetTypesOverrides.js +15 -0
- package/Libraries/StyleSheet/private/_TransformStyle.js +53 -0
- package/Libraries/StyleSheet/processTransform.windows.js +272 -0
- package/Libraries/Text/Text.js +13 -7
- package/Libraries/Text/Text.windows.js +16 -7
- package/Libraries/Text/TextNativeComponent.js +2 -0
- package/Libraries/Text/TextProps.js +10 -0
- package/Libraries/Types/CoreEventTypes.js +13 -1
- package/Libraries/Types/CoreEventTypes.windows.js +26 -1
- package/Libraries/Utilities/Appearance.js +0 -8
- package/Libraries/Utilities/HMRClient.js +1 -1
- package/Libraries/Utilities/ReactNativeTestTools.js +1 -0
- package/Libraries/Utilities/codegenNativeComponent.js +17 -6
- package/Libraries/Utilities/stringifySafe.js +4 -1
- package/Libraries/Utilities/verifyComponentAttributeEquivalence.js +3 -3
- package/Libraries/WebSocket/WebSocket.js +1 -1
- package/Libraries/vendor/emitter/_EmitterSubscription.js +1 -1
- package/Libraries/vendor/emitter/_EventEmitter.js +1 -1
- package/Libraries/vendor/emitter/_EventSubscription.js +1 -1
- package/Microsoft.ReactNative/DynamicReader.cpp +3 -3
- package/Microsoft.ReactNative/Fabric/ComponentView.h +1 -0
- package/Microsoft.ReactNative/Fabric/ComponentViewRegistry.cpp +36 -2
- package/Microsoft.ReactNative/Fabric/ComponentViewRegistry.h +1 -0
- package/Microsoft.ReactNative/Fabric/DWriteHelpers.cpp +19 -0
- package/Microsoft.ReactNative/Fabric/DWriteHelpers.h +13 -0
- package/Microsoft.ReactNative/Fabric/FabricUIManagerModule.cpp +65 -19
- package/Microsoft.ReactNative/Fabric/FabricUIManagerModule.h +2 -0
- package/Microsoft.ReactNative/Fabric/ParagraphComponentView.cpp +36 -10
- package/Microsoft.ReactNative/Fabric/ScrollViewComponentView.cpp +2 -0
- package/Microsoft.ReactNative/Fabric/SliderComponentView.cpp +107 -0
- package/Microsoft.ReactNative/Fabric/SliderComponentView.h +51 -0
- package/Microsoft.ReactNative/Fabric/SwitchComponentView.cpp +109 -0
- package/Microsoft.ReactNative/Fabric/SwitchComponentView.h +52 -0
- package/Microsoft.ReactNative/Fabric/TextInput/WindowsTextInputComponentDescriptor.h +197 -0
- package/Microsoft.ReactNative/Fabric/TextInput/WindowsTextInputComponentView.cpp +308 -0
- package/Microsoft.ReactNative/Fabric/TextInput/WindowsTextInputComponentView.h +52 -0
- package/Microsoft.ReactNative/Fabric/TextInput/WindowsTextInputEventEmitter.cpp +31 -0
- package/Microsoft.ReactNative/Fabric/TextInput/WindowsTextInputEventEmitter.h +33 -0
- package/Microsoft.ReactNative/Fabric/TextInput/WindowsTextInputProps.cpp +81 -0
- package/Microsoft.ReactNative/Fabric/TextInput/WindowsTextInputProps.h +132 -0
- package/Microsoft.ReactNative/Fabric/TextInput/WindowsTextInputShadowNode.cpp +193 -0
- package/Microsoft.ReactNative/Fabric/TextInput/WindowsTextInputShadowNode.h +85 -0
- package/Microsoft.ReactNative/Fabric/TextInput/WindowsTextInputState.cpp +76 -0
- package/Microsoft.ReactNative/Fabric/TextInput/WindowsTextInputState.h +99 -0
- package/Microsoft.ReactNative/Fabric/ViewComponentView.cpp +35 -3
- package/Microsoft.ReactNative/Fabric/ViewComponentView.h +1 -0
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/components/rncore/EventEmitters.h +5 -0
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/components/rncore/Props.h +5 -0
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/components/slider/SliderMeasurementsManager.cpp +46 -0
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/components/slider/SliderMeasurementsManager.h +30 -0
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/graphics/Color.cpp +2 -0
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/graphics/conversions.h +1 -9
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/graphics/platform/cxx/react/renderer/graphics/Color.h +3 -1
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/textlayoutmanager/TextLayoutManager.cpp +119 -57
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/textlayoutmanager/TextLayoutManager.h +18 -1
- package/Microsoft.ReactNative/IViewManager.idl +3 -3
- package/Microsoft.ReactNative/Microsoft.ReactNative.vcxproj +13 -107
- package/Microsoft.ReactNative/Microsoft.ReactNative.vcxproj.filters +2 -2
- package/Microsoft.ReactNative/Modules/AppStateModule.cpp +2 -0
- package/Microsoft.ReactNative/Modules/AppStateModule.h +2 -0
- package/Microsoft.ReactNative/Modules/CreateModules.cpp +3 -3
- package/Microsoft.ReactNative/Modules/NativeUIManager.cpp +7 -5
- package/Microsoft.ReactNative/Modules/TimingModule.cpp +2 -2
- package/Microsoft.ReactNative/Modules/TimingModule.h +2 -2
- package/Microsoft.ReactNative/ReactHost/{ReactContext.cpp → MsoReactContext.cpp} +1 -1
- package/Microsoft.ReactNative/ReactHost/{ReactContext.h → MsoReactContext.h} +0 -0
- package/Microsoft.ReactNative/ReactHost/ReactInstanceWin.cpp +14 -1
- package/Microsoft.ReactNative/ReactHost/ReactInstanceWin.h +1 -1
- package/Microsoft.ReactNative/ReactHost/ReactNativeHeaders.h +1 -1
- package/Microsoft.ReactNative/ReactRootView.cpp +2 -1
- package/Microsoft.ReactNative/RedBox.cpp +3 -2
- package/Microsoft.ReactNative/Utils/ValueUtils.cpp +3 -2
- package/Microsoft.ReactNative/Views/ControlViewManager.cpp +32 -0
- package/Microsoft.ReactNative/Views/ControlViewManager.h +11 -0
- package/Microsoft.ReactNative/Views/DevMenu.cpp +2 -2
- package/Microsoft.ReactNative/Views/FrameworkElementTransferProperties.cpp +13 -2
- package/Microsoft.ReactNative/Views/FrameworkElementViewManager.cpp +149 -22
- package/Microsoft.ReactNative/Views/Image/ImageViewManager.cpp +1 -1
- package/Microsoft.ReactNative/Views/Image/Microsoft.UI.Composition.Effects_Impl.h +5 -11
- package/Microsoft.ReactNative/Views/Image/ReactImage.cpp +2 -1
- package/Microsoft.ReactNative/Views/SliderViewManager.cpp +12 -4
- package/Microsoft.ReactNative/Views/TextInputViewManager.cpp +1 -1
- package/Microsoft.ReactNative/Views/TextViewManager.cpp +2 -2
- package/Microsoft.ReactNative/Views/TouchEventHandler.cpp +163 -37
- package/Microsoft.ReactNative/Views/TouchEventHandler.h +11 -4
- package/Microsoft.ReactNative/Views/ViewPanel.cpp +3 -23
- package/Microsoft.ReactNative/Views/ViewPanel.h +2 -3
- package/Microsoft.ReactNative/Views/ViewViewManager.cpp +21 -0
- package/Microsoft.ReactNative/XamlUIService.cpp +1 -1
- package/Microsoft.ReactNative/XamlView.h +8 -3
- package/Microsoft.ReactNative.Cxx/CppWinRTIncludes.h +3 -5
- package/Microsoft.ReactNative.Cxx/DesktopWindowBridge.h +1 -1
- package/Microsoft.ReactNative.Cxx/JSI/JsiAbiApi.cpp +11 -2
- package/Microsoft.ReactNative.Cxx/JSI/JsiAbiApi.h +1 -0
- package/Microsoft.ReactNative.Cxx/JSI/NodeApiJsiRuntime.cpp +10 -1
- package/Microsoft.ReactNative.Cxx/JSValueReader.h +2 -2
- package/Microsoft.ReactNative.Cxx/JSValueWriter.h +5 -5
- package/Microsoft.ReactNative.Cxx/Microsoft.ReactNative.Cxx.vcxitems +5 -1
- package/Microsoft.ReactNative.Cxx/Microsoft.ReactNative.Cxx.vcxitems.filters +2 -3
- package/Microsoft.ReactNative.Cxx/NativeModules.h +1 -1
- package/Microsoft.ReactNative.Cxx/ReactContext.h +3 -3
- package/Microsoft.ReactNative.Cxx/ReactNonAbiValue.h +3 -3
- package/Microsoft.ReactNative.Cxx/XamlUtils.h +44 -5
- package/Microsoft.ReactNative.Managed/Microsoft.ReactNative.Managed.csproj +0 -6
- package/Mso/activeObject/activeObject.h +2 -2
- package/Mso/compilerAdapters/cppMacros.h +3 -5
- package/Mso/errorCode/errorProvider.h +2 -2
- package/Mso/errorCode/maybe.h +4 -4
- package/Mso/functional/functor.h +6 -6
- package/Mso/functional/functorRef.h +2 -2
- package/Mso/future/details/executor.h +2 -2
- package/Mso/future/details/futureFuncInl.h +4 -4
- package/Mso/future/details/ifuture.h +3 -3
- package/Mso/future/details/maybeInvoker.h +6 -6
- package/Mso/future/details/promiseGroupInl.h +4 -4
- package/Mso/future/details/promiseInl.h +4 -4
- package/Mso/future/details/resultTraits.h +4 -4
- package/Mso/future/details/whenAllInl.h +1 -1
- package/Mso/future/future.h +13 -13
- package/Mso/guid/msoGuidDetails.h +1 -1
- package/Mso/memoryApi/memoryApi.h +13 -7
- package/Mso/motifCpp/gTestAdapter.h +1 -1
- package/Mso/motifCpp/testInfo.h +7 -9
- package/Mso/object/make.h +8 -8
- package/Mso/object/objectRefCount.h +3 -5
- package/Mso/object/objectWithWeakRef.h +10 -14
- package/Mso/object/queryCast.h +4 -4
- package/Mso/object/refCountedObject.h +4 -4
- package/Mso/object/unknownObject.h +7 -7
- package/Mso/platformAdapters/windowsFirst.h +1 -1
- package/Mso/smartPtr/cntPtr.h +8 -8
- package/Mso/src/dispatchQueue/uiScheduler_winrt.cpp +2 -2
- package/Mso/src/future/futureImpl.h +1 -1
- package/Mso/src/memoryApi/memoryApi.cpp +4 -4
- package/PropertySheets/CppAppConsumeCSharpModule.props +3 -0
- package/PropertySheets/External/Microsoft.ReactNative.WinAppSDK.CSharpApp.props +26 -0
- package/PropertySheets/External/Microsoft.ReactNative.WinAppSDK.Common.props +12 -0
- package/PropertySheets/Generated/PackageVersion.g.props +3 -3
- package/PropertySheets/React.Cpp.props +13 -0
- package/PropertySheets/WinUI.props +3 -6
- package/ReactCommon/ReactCommon.vcxproj +2 -4
- package/ReactCommon/ReactCommon.vcxproj.filters +4 -1
- package/ReactCommon/TEMP_UntilReactCommonUpdate/jsi/JSCRuntime.cpp +1480 -0
- package/ReactCommon/TEMP_UntilReactCommonUpdate/jsi/jsi/decorator.h +753 -0
- package/ReactCommon/TEMP_UntilReactCommonUpdate/jsi/jsi/jsi.h +1331 -0
- package/ReactCommon/TEMP_UntilReactCommonUpdate/jsi/jsi/test/testlib.cpp +1431 -0
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/bridging/CallbackWrapper.h +103 -0
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/nativemodule/core/ReactCommon/TurboModule.h +87 -0
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/nativemodule/core/ReactCommon/TurboModuleUtils.h +61 -0
- package/ReactCommon/Yoga.cpp +1 -1
- package/Scripts/{Microsoft.ReactNative.ProjectReunion.nuspec → Microsoft.ReactNative.WindowsAppSDK.nuspec} +7 -9
- package/Scripts/OfficeReact.Win32.nuspec +1 -3
- package/Scripts/Tfs/Layout-MSRN-Headers.ps1 +2 -1
- package/Scripts/copyRNLibraries.js +8 -8
- package/Scripts/just.js +1 -1
- package/Scripts/rnw-dependencies.ps1 +41 -10
- package/Scripts/run-desktop-integration-tests.js +6 -6
- package/Shared/AbiSafe.h +3 -3
- package/Shared/BaseScriptStoreImpl.cpp +1 -1
- package/Shared/CppRuntimeOptions.h +50 -0
- package/Shared/DevSupportManager.cpp +32 -36
- package/Shared/DevSupportManager.h +1 -2
- package/Shared/HermesRuntimeHolder.cpp +23 -14
- package/Shared/HermesRuntimeHolder.h +8 -2
- package/Shared/IDevSupportManager.h +1 -2
- package/Shared/InspectorPackagerConnection.cpp +7 -5
- package/Shared/InspectorPackagerConnection.h +2 -2
- package/Shared/JSI/ChakraApi.cpp +0 -1
- package/Shared/JSI/ChakraRuntime.cpp +1 -2
- package/Shared/JSI/RuntimeHolder.h +2 -0
- package/Shared/Modules/HttpModule.cpp +1 -1
- package/Shared/Modules/HttpModule.h +2 -2
- package/Shared/Modules/WebSocketModule.cpp +1 -1
- package/Shared/Modules/WebSocketModule.h +8 -5
- package/Shared/{IHttpResource.h → Networking/IHttpResource.h} +4 -4
- package/Shared/{IWebSocketResource.h → Networking/IWebSocketResource.h} +2 -2
- package/Shared/Networking/OriginPolicy.h +15 -0
- package/Shared/Networking/OriginPolicyHttpFilter.cpp +746 -0
- package/Shared/Networking/OriginPolicyHttpFilter.h +112 -0
- package/Shared/{WinRTHttpResource.cpp → Networking/WinRTHttpResource.cpp} +129 -99
- package/Shared/{WinRTHttpResource.h → Networking/WinRTHttpResource.h} +8 -12
- package/Shared/Networking/WinRTTypes.h +30 -0
- package/Shared/{WinRTWebSocketResource.cpp → Networking/WinRTWebSocketResource.cpp} +2 -2
- package/Shared/{WinRTWebSocketResource.h → Networking/WinRTWebSocketResource.h} +3 -3
- package/Shared/OInstance.cpp +5 -5
- package/Shared/RuntimeOptions.cpp +93 -15
- package/Shared/RuntimeOptions.h +22 -9
- package/Shared/Shared.vcxitems +122 -7
- package/Shared/Shared.vcxitems.filters +40 -21
- package/Shared/Threading/BatchingQueueThread.cpp +1 -1
- package/Shared/tracing/fbsystrace.h +2 -2
- package/codegen/NativeActionSheetManagerSpec.g.h +6 -0
- package/codegen/NativeAnimatedModuleSpec.g.h +43 -37
- package/codegen/NativeAnimatedTurboModuleSpec.g.h +43 -37
- package/codegen/NativePushNotificationManagerIOSSpec.g.h +2 -0
- package/codegen/react/components/rnwcore/ComponentDescriptors.h +0 -1
- package/codegen/react/components/rnwcore/EventEmitters.cpp +133 -0
- package/codegen/react/components/rnwcore/EventEmitters.h +0 -18
- package/codegen/react/components/rnwcore/Props.cpp +0 -13
- package/codegen/react/components/rnwcore/Props.h +0 -16
- package/codegen/react/components/rnwcore/ShadowNodes.cpp +0 -1
- package/codegen/react/components/rnwcore/ShadowNodes.h +0 -10
- package/include/Shared/cdebug.h +9 -9
- package/index.js +30 -25
- package/index.windows.js +30 -25
- package/jest/preprocessor.js +24 -107
- package/jest/preprocessor_DO_NOT_USE.js +122 -0
- package/metro.config.js +3 -70
- package/package.json +29 -28
- package/react-native.config.js +40 -6
- package/rntypes/index.d.ts +19 -7
- package/stubs/glog/logging.h +1 -1
- package/template/cpp-app/src/App.h +0 -4
- package/template/cs-app/src/App.xaml.cs +0 -5
- package/template/cs-app/src/MainPage.xaml.cs +1 -10
- package/template/cs-app-WinAppSDK/MyApp/App.xaml +16 -0
- package/template/cs-app-WinAppSDK/MyApp/App.xaml.cs +70 -0
- package/template/cs-app-WinAppSDK/MyApp/MainWindow.xaml +14 -0
- package/template/cs-app-WinAppSDK/MyApp/MainWindow.xaml.cs +38 -0
- package/template/cs-app-WinAppSDK/MyApp/Package.appxmanifest +48 -0
- package/template/cs-app-WinAppSDK/MyApp/Properties/PublishProfiles/win10-arm64.pubxml +19 -0
- package/template/cs-app-WinAppSDK/MyApp/Properties/PublishProfiles/win10-x64.pubxml +19 -0
- package/template/cs-app-WinAppSDK/MyApp/Properties/PublishProfiles/win10-x86.pubxml +19 -0
- package/template/cs-app-WinAppSDK/MyApp/Properties/launchSettings.json +10 -0
- package/template/cs-app-WinAppSDK/MyApp/app.manifest +15 -0
- package/template/cs-app-WinAppSDK/proj/ExperimentalFeatures.props +23 -0
- package/template/cs-app-WinAppSDK/proj/MyApp.csproj +49 -0
- package/template/cs-app-WinAppSDK/proj/MyApp.sln +43 -0
- package/template/cs-app-WinAppSDK/proj/NuGet.Config +17 -0
- package/template/metro.devMode.config.js +2 -51
- package/typings-index.js +5 -1
- package/typings-index.js.map +1 -1
- package/Libraries/Components/SegmentedControlIOS/RCTSegmentedControlNativeComponent.js +0 -44
- package/Libraries/Components/SegmentedControlIOS/SegmentedControlIOS.android.js +0 -45
- package/Libraries/Components/SegmentedControlIOS/SegmentedControlIOS.ios.js +0 -123
- package/Libraries/Components/SegmentedControlIOS/SegmentedControlIOS.windows.js +0 -45
- package/Libraries/Components/View/ReactNativeViewViewConfig.js +0 -360
- package/Libraries/Components/View/ReactNativeViewViewConfig.windows.js +0 -390
- package/Libraries/Components/View/ReactNativeViewViewConfigAndroid.js +0 -83
- package/Libraries/ReactNative/UIManagerInjection.js +0 -15
- package/Libraries/Renderer/implementations/ReactFabric-dev.fb.js +0 -24527
- package/Libraries/Renderer/implementations/ReactFabric-prod.fb.js +0 -8309
- package/Libraries/Renderer/implementations/ReactFabric-profiling.fb.js +0 -8961
- package/Libraries/Renderer/implementations/ReactNativeRenderer-dev.fb.js +0 -24948
- package/Libraries/Renderer/implementations/ReactNativeRenderer-prod.fb.js +0 -8400
- package/Libraries/Renderer/implementations/ReactNativeRenderer-profiling.fb.js +0 -9049
- package/PropertySheets/CppEnablePackageReferences.props +0 -13
- package/Shared/cdebug.cpp +0 -6
- package/include/Shared/ViewManager.h +0 -34
|
@@ -33,6 +33,7 @@
|
|
|
33
33
|
#pragma warning(pop)
|
|
34
34
|
|
|
35
35
|
#include <future>
|
|
36
|
+
#include <mutex>
|
|
36
37
|
|
|
37
38
|
#include <AppModel.h>
|
|
38
39
|
|
|
@@ -69,13 +70,13 @@ std::future<std::pair<std::string, bool>> GetJavaScriptFromServerAsync(const std
|
|
|
69
70
|
|
|
70
71
|
HRESULT hr = asyncRequest.ErrorCode();
|
|
71
72
|
if (FAILED(hr)) {
|
|
72
|
-
std::
|
|
73
|
+
std::string error;
|
|
73
74
|
if (hr == WININET_E_CANNOT_CONNECT) {
|
|
74
|
-
|
|
75
|
+
error = fmt::format("A connection with the server {} could not be established.\n\nIs the packager running?", url);
|
|
75
76
|
} else {
|
|
76
|
-
|
|
77
|
+
error = fmt::format("Error 0x{:x} downloading {}.", static_cast<int>(asyncRequest.ErrorCode()), url);
|
|
77
78
|
}
|
|
78
|
-
co_return std::make_pair(
|
|
79
|
+
co_return std::make_pair(error, false);
|
|
79
80
|
}
|
|
80
81
|
|
|
81
82
|
winrt::Windows::Web::Http::HttpResponseMessage response = asyncRequest.GetResults();
|
|
@@ -88,15 +89,15 @@ std::future<std::pair<std::string, bool>> GetJavaScriptFromServerAsync(const std
|
|
|
88
89
|
uint32_t len = reader.UnconsumedBufferLength();
|
|
89
90
|
std::string result;
|
|
90
91
|
if (len > 0 || response.IsSuccessStatusCode()) {
|
|
91
|
-
std::
|
|
92
|
+
std::string data;
|
|
92
93
|
data.resize(len);
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
94
|
+
auto buf = reinterpret_cast<uint8_t *>(data.data());
|
|
95
|
+
static_assert(
|
|
96
|
+
sizeof(buf[0]) == sizeof(data[0]), "perf optimization relies on uint8_t and char being the same size");
|
|
97
|
+
reader.ReadBytes(winrt::array_view(buf, buf + len));
|
|
98
|
+
result = std::move(data);
|
|
96
99
|
} else {
|
|
97
|
-
|
|
98
|
-
sstream << "HTTP Error " << static_cast<int>(response.StatusCode()) << " downloading " << url;
|
|
99
|
-
result = sstream.str();
|
|
100
|
+
result = fmt::format("HTTP Error {} downloading {}.", static_cast<int>(response.StatusCode()), url);
|
|
100
101
|
}
|
|
101
102
|
|
|
102
103
|
co_return std::make_pair(std::move(result), response.IsSuccessStatusCode());
|
|
@@ -239,37 +240,32 @@ void DevSupportManager::StopPollingLiveReload() {
|
|
|
239
240
|
m_cancellation_token = true;
|
|
240
241
|
}
|
|
241
242
|
|
|
242
|
-
void DevSupportManager::
|
|
243
|
+
void DevSupportManager::EnsureHermesInspector(
|
|
243
244
|
[[maybe_unused]] const std::string &packagerHost,
|
|
244
245
|
[[maybe_unused]] const uint16_t packagerPort) noexcept {
|
|
245
246
|
#ifdef HERMES_ENABLE_DEBUGGER
|
|
246
|
-
std::
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
247
|
+
static std::once_flag once;
|
|
248
|
+
std::call_once(once, [this, &packagerHost, packagerPort]() {
|
|
249
|
+
std::string packageName("RNW");
|
|
250
|
+
wchar_t fullName[PACKAGE_FULL_NAME_MAX_LENGTH]{};
|
|
251
|
+
UINT32 size = ARRAYSIZE(fullName);
|
|
252
|
+
if (SUCCEEDED(GetCurrentPackageFullName(&size, fullName))) {
|
|
253
|
+
// we are in an unpackaged app
|
|
254
|
+
packageName = winrt::to_string(fullName);
|
|
255
|
+
}
|
|
253
256
|
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
257
|
+
std::string deviceName("RNWHost");
|
|
258
|
+
auto hostNames = winrt::Windows::Networking::Connectivity::NetworkInformation::GetHostNames();
|
|
259
|
+
if (hostNames && hostNames.First() && hostNames.First().Current()) {
|
|
260
|
+
deviceName = winrt::to_string(hostNames.First().Current().DisplayName());
|
|
261
|
+
}
|
|
259
262
|
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
}
|
|
263
|
+
m_inspectorPackagerConnection = std::make_shared<InspectorPackagerConnection>(
|
|
264
|
+
facebook::react::DevServerHelper::get_InspectorDeviceUrl(packagerHost, packagerPort, deviceName, packageName),
|
|
265
|
+
m_BundleStatusProvider);
|
|
266
|
+
m_inspectorPackagerConnection->connectAsync();
|
|
267
|
+
});
|
|
266
268
|
|
|
267
|
-
void DevSupportManager::StopInspector() noexcept {
|
|
268
|
-
#ifdef HERMES_ENABLE_DEBUGGER
|
|
269
|
-
if (m_inspectorPackagerConnection) {
|
|
270
|
-
m_inspectorPackagerConnection->disconnectAsync();
|
|
271
|
-
m_inspectorPackagerConnection = nullptr;
|
|
272
|
-
}
|
|
273
269
|
#endif
|
|
274
270
|
}
|
|
275
271
|
|
|
@@ -50,8 +50,7 @@ class DevSupportManager final : public facebook::react::IDevSupportManager {
|
|
|
50
50
|
std::function<void()> onChangeCallback) override;
|
|
51
51
|
virtual void StopPollingLiveReload() override;
|
|
52
52
|
|
|
53
|
-
virtual void
|
|
54
|
-
virtual void StopInspector() noexcept override;
|
|
53
|
+
virtual void EnsureHermesInspector(const std::string &packagerHost, const uint16_t packagerPort) noexcept override;
|
|
55
54
|
virtual void UpdateBundleStatus(bool isLastDownloadSucess, int64_t updateTimestamp) noexcept override;
|
|
56
55
|
|
|
57
56
|
private:
|
|
@@ -74,7 +74,15 @@ class HermesExecutorRuntimeAdapter final : public facebook::hermes::inspector::R
|
|
|
74
74
|
} // namespace
|
|
75
75
|
|
|
76
76
|
void HermesRuntimeHolder::crashHandler(int fileDescriptor) noexcept {
|
|
77
|
-
HermesShim::hermesCrashHandler(
|
|
77
|
+
HermesShim::hermesCrashHandler(*m_hermesRuntime, fileDescriptor);
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
void HermesRuntimeHolder::teardown() noexcept {
|
|
81
|
+
#ifdef HERMES_ENABLE_DEBUGGER
|
|
82
|
+
if (auto devSettings = m_weakDevSettings.lock(); devSettings && devSettings->useDirectDebugger) {
|
|
83
|
+
facebook::hermes::inspector::chrome::disableDebugging(*m_hermesRuntime);
|
|
84
|
+
}
|
|
85
|
+
#endif
|
|
78
86
|
}
|
|
79
87
|
|
|
80
88
|
facebook::react::JSIEngineOverride HermesRuntimeHolder::getRuntimeType() noexcept {
|
|
@@ -84,43 +92,44 @@ facebook::react::JSIEngineOverride HermesRuntimeHolder::getRuntimeType() noexcep
|
|
|
84
92
|
std::shared_ptr<jsi::Runtime> HermesRuntimeHolder::getRuntime() noexcept {
|
|
85
93
|
std::call_once(m_once_flag, [this]() { initRuntime(); });
|
|
86
94
|
|
|
87
|
-
if (!
|
|
95
|
+
if (!m_hermesRuntime)
|
|
88
96
|
std::terminate();
|
|
89
97
|
|
|
90
98
|
// Make sure that the runtime instance is not consumed from multiple threads.
|
|
91
99
|
if (m_own_thread_id != std::this_thread::get_id())
|
|
92
100
|
std::terminate();
|
|
93
101
|
|
|
94
|
-
return
|
|
102
|
+
return m_hermesRuntime;
|
|
95
103
|
}
|
|
96
104
|
|
|
97
105
|
HermesRuntimeHolder::HermesRuntimeHolder(
|
|
98
106
|
std::shared_ptr<facebook::react::DevSettings> devSettings,
|
|
99
107
|
std::shared_ptr<facebook::react::MessageQueueThread> jsQueue) noexcept
|
|
100
|
-
:
|
|
108
|
+
: m_weakDevSettings(devSettings), m_jsQueue(std::move(jsQueue)) {}
|
|
101
109
|
|
|
102
110
|
void HermesRuntimeHolder::initRuntime() noexcept {
|
|
103
|
-
auto
|
|
104
|
-
|
|
105
|
-
|
|
111
|
+
auto devSettings = m_weakDevSettings.lock();
|
|
112
|
+
if (!devSettings)
|
|
113
|
+
std::terminate();
|
|
106
114
|
|
|
107
|
-
|
|
115
|
+
m_hermesRuntime = makeHermesRuntimeSystraced(devSettings->enableDefaultCrashHandler);
|
|
108
116
|
m_own_thread_id = std::this_thread::get_id();
|
|
109
117
|
|
|
110
118
|
#ifdef HERMES_ENABLE_DEBUGGER
|
|
111
|
-
if (
|
|
112
|
-
auto adapter = std::make_unique<HermesExecutorRuntimeAdapter>(
|
|
119
|
+
if (devSettings->useDirectDebugger) {
|
|
120
|
+
auto adapter = std::make_unique<HermesExecutorRuntimeAdapter>(m_hermesRuntime, *m_hermesRuntime, m_jsQueue);
|
|
113
121
|
facebook::hermes::inspector::chrome::enableDebugging(
|
|
114
122
|
std::move(adapter),
|
|
115
|
-
|
|
123
|
+
devSettings->debuggerRuntimeName.empty() ? "Hermes React Native" : devSettings->debuggerRuntimeName);
|
|
116
124
|
}
|
|
117
125
|
#endif
|
|
118
126
|
|
|
119
127
|
// Add js engine information to Error.prototype so in error reporting we
|
|
120
128
|
// can send this information.
|
|
121
|
-
auto errorPrototype =
|
|
122
|
-
|
|
123
|
-
|
|
129
|
+
auto errorPrototype = m_hermesRuntime->global()
|
|
130
|
+
.getPropertyAsObject(*m_hermesRuntime, "Error")
|
|
131
|
+
.getPropertyAsObject(*m_hermesRuntime, "prototype");
|
|
132
|
+
errorPrototype.setProperty(*m_hermesRuntime, "jsEngine", "hermes");
|
|
124
133
|
}
|
|
125
134
|
|
|
126
135
|
} // namespace react
|
|
@@ -9,6 +9,10 @@
|
|
|
9
9
|
|
|
10
10
|
#include <DevSettings.h>
|
|
11
11
|
|
|
12
|
+
namespace facebook::hermes {
|
|
13
|
+
class HermesRuntime;
|
|
14
|
+
}
|
|
15
|
+
|
|
12
16
|
namespace facebook {
|
|
13
17
|
namespace react {
|
|
14
18
|
|
|
@@ -19,18 +23,20 @@ class HermesRuntimeHolder : public Microsoft::JSI::RuntimeHolderLazyInit {
|
|
|
19
23
|
|
|
20
24
|
void crashHandler(int fileDescriptor) noexcept override;
|
|
21
25
|
|
|
26
|
+
void teardown() noexcept override;
|
|
27
|
+
|
|
22
28
|
HermesRuntimeHolder(
|
|
23
29
|
std::shared_ptr<facebook::react::DevSettings> devSettings,
|
|
24
30
|
std::shared_ptr<facebook::react::MessageQueueThread> jsQueue) noexcept;
|
|
25
31
|
|
|
26
32
|
private:
|
|
27
33
|
void initRuntime() noexcept;
|
|
28
|
-
std::shared_ptr<facebook::
|
|
34
|
+
std::shared_ptr<facebook::hermes::HermesRuntime> m_hermesRuntime;
|
|
29
35
|
|
|
30
36
|
std::once_flag m_once_flag;
|
|
31
37
|
std::thread::id m_own_thread_id;
|
|
32
38
|
|
|
33
|
-
std::
|
|
39
|
+
std::weak_ptr<facebook::react::DevSettings> m_weakDevSettings;
|
|
34
40
|
std::shared_ptr<facebook::react::MessageQueueThread> m_jsQueue;
|
|
35
41
|
};
|
|
36
42
|
|
|
@@ -22,8 +22,7 @@ struct IDevSupportManager {
|
|
|
22
22
|
std::function<void()> onChangeCallback) = 0;
|
|
23
23
|
virtual void StopPollingLiveReload() = 0;
|
|
24
24
|
|
|
25
|
-
virtual void
|
|
26
|
-
virtual void StopInspector() noexcept = 0;
|
|
25
|
+
virtual void EnsureHermesInspector(const std::string &packagerHost, const uint16_t packagerPort) noexcept = 0;
|
|
27
26
|
virtual void UpdateBundleStatus(bool isLastDownloadSucess, int64_t updateTimestamp) noexcept = 0;
|
|
28
27
|
};
|
|
29
28
|
|
|
@@ -196,7 +196,8 @@ InspectorPackagerConnection::InspectorPackagerConnection(
|
|
|
196
196
|
winrt::fire_and_forget InspectorPackagerConnection::disconnectAsync() {
|
|
197
197
|
co_await winrt::resume_background();
|
|
198
198
|
std::string reason("Explicit close");
|
|
199
|
-
m_packagerWebSocketConnection->Close(
|
|
199
|
+
m_packagerWebSocketConnection->Close(
|
|
200
|
+
Microsoft::React::Networking::WinRTWebSocketResource::CloseCode::GoingAway, reason);
|
|
200
201
|
co_return;
|
|
201
202
|
}
|
|
202
203
|
|
|
@@ -204,9 +205,10 @@ winrt::fire_and_forget InspectorPackagerConnection::connectAsync() {
|
|
|
204
205
|
co_await winrt::resume_background();
|
|
205
206
|
|
|
206
207
|
std::vector<winrt::Windows::Security::Cryptography::Certificates::ChainValidationResult> certExceptions;
|
|
207
|
-
m_packagerWebSocketConnection =
|
|
208
|
+
m_packagerWebSocketConnection =
|
|
209
|
+
std::make_shared<Microsoft::React::Networking::WinRTWebSocketResource>(std::move(certExceptions));
|
|
208
210
|
|
|
209
|
-
m_packagerWebSocketConnection->SetOnError([](const Microsoft::React::IWebSocketResource::Error &err) {
|
|
211
|
+
m_packagerWebSocketConnection->SetOnError([](const Microsoft::React::Networking::IWebSocketResource::Error &err) {
|
|
210
212
|
facebook::react::tracing::error(err.Message.c_str());
|
|
211
213
|
});
|
|
212
214
|
|
|
@@ -267,8 +269,8 @@ winrt::fire_and_forget InspectorPackagerConnection::connectAsync() {
|
|
|
267
269
|
}
|
|
268
270
|
});
|
|
269
271
|
|
|
270
|
-
Microsoft::React::IWebSocketResource::Protocols protocols;
|
|
271
|
-
Microsoft::React::IWebSocketResource::Options options;
|
|
272
|
+
Microsoft::React::Networking::IWebSocketResource::Protocols protocols;
|
|
273
|
+
Microsoft::React::Networking::IWebSocketResource::Options options;
|
|
272
274
|
m_packagerWebSocketConnection->Connect(std::string{m_url}, protocols, options);
|
|
273
275
|
|
|
274
276
|
co_return;
|
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
#pragma once
|
|
5
5
|
|
|
6
6
|
#include <InspectorProxy.h>
|
|
7
|
-
#include <WinRTWebSocketResource.h>
|
|
7
|
+
#include <Networking/WinRTWebSocketResource.h>
|
|
8
8
|
#include <jsinspector/InspectorInterfaces.h>
|
|
9
9
|
|
|
10
10
|
namespace Microsoft::ReactNative {
|
|
@@ -42,7 +42,7 @@ class InspectorPackagerConnection final : public std::enable_shared_from_this<In
|
|
|
42
42
|
void sendMessageToVM(int64_t pageId, std::string &&message);
|
|
43
43
|
|
|
44
44
|
std::unordered_map<int64_t, std::unique_ptr<facebook::react::ILocalConnection>> m_localConnections;
|
|
45
|
-
std::shared_ptr<Microsoft::React::WinRTWebSocketResource> m_packagerWebSocketConnection;
|
|
45
|
+
std::shared_ptr<Microsoft::React::Networking::WinRTWebSocketResource> m_packagerWebSocketConnection;
|
|
46
46
|
std::shared_ptr<IBundleStatusProvider> m_bundleStatusProvider;
|
|
47
47
|
std::string m_url;
|
|
48
48
|
};
|
package/Shared/JSI/ChakraApi.cpp
CHANGED
|
@@ -4,7 +4,6 @@
|
|
|
4
4
|
#include "ChakraRuntime.h"
|
|
5
5
|
#include "ChakraRuntimeFactory.h"
|
|
6
6
|
|
|
7
|
-
#include <RuntimeOptions.h>
|
|
8
7
|
#include "Unicode.h"
|
|
9
8
|
#include "Utilities.h"
|
|
10
9
|
|
|
@@ -991,7 +990,7 @@ size_t ChakraRuntime::JsiValueViewArgs::Size() const noexcept {
|
|
|
991
990
|
|
|
992
991
|
ChakraRuntime::PropNameIDView::PropNameIDView(JsPropertyIdRef propertyId) noexcept
|
|
993
992
|
: m_propertyId{
|
|
994
|
-
make<facebook::jsi::PropNameID>(new
|
|
993
|
+
make<facebook::jsi::PropNameID>(new(std::addressof(m_pointerStore)) ChakraPointerValueView(propertyId))} {}
|
|
995
994
|
|
|
996
995
|
ChakraRuntime::PropNameIDView::~PropNameIDView() noexcept {}
|
|
997
996
|
|
|
@@ -18,6 +18,8 @@ struct RuntimeHolderLazyInit {
|
|
|
18
18
|
virtual std::shared_ptr<facebook::jsi::Runtime> getRuntime() noexcept = 0;
|
|
19
19
|
virtual facebook::react::JSIEngineOverride getRuntimeType() noexcept = 0;
|
|
20
20
|
|
|
21
|
+
virtual void teardown() noexcept {};
|
|
22
|
+
|
|
21
23
|
// You can call this when a crash happens to attempt recording additional data
|
|
22
24
|
// The fd supplied is a raw file stream an implementation might write JSON to
|
|
23
25
|
virtual void crashHandler(int fileDescriptor) noexcept {};
|
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
|
|
4
4
|
#pragma once
|
|
5
5
|
|
|
6
|
-
#include
|
|
6
|
+
#include <Networking/IHttpResource.h>
|
|
7
7
|
|
|
8
8
|
// React Native
|
|
9
9
|
#include <cxxreact/CxxModule.h>
|
|
@@ -47,7 +47,7 @@ class HttpModule : public facebook::xplat::module::CxxModule {
|
|
|
47
47
|
HttpModule *Module{nullptr};
|
|
48
48
|
};
|
|
49
49
|
|
|
50
|
-
std::shared_ptr<IHttpResource> m_resource;
|
|
50
|
+
std::shared_ptr<Networking::IHttpResource> m_resource;
|
|
51
51
|
std::shared_ptr<ModuleHolder> m_holder;
|
|
52
52
|
};
|
|
53
53
|
} // namespace Microsoft::React
|
|
@@ -26,8 +26,8 @@ using std::string;
|
|
|
26
26
|
using std::weak_ptr;
|
|
27
27
|
|
|
28
28
|
namespace {
|
|
29
|
-
using Microsoft::React::IWebSocketResource;
|
|
30
29
|
using Microsoft::React::WebSocketModule;
|
|
30
|
+
using Microsoft::React::Networking::IWebSocketResource;
|
|
31
31
|
|
|
32
32
|
constexpr char moduleName[] = "WebSocketModule";
|
|
33
33
|
|
|
@@ -3,8 +3,10 @@
|
|
|
3
3
|
|
|
4
4
|
#pragma once
|
|
5
5
|
|
|
6
|
+
#include <Networking/IWebSocketResource.h>
|
|
7
|
+
|
|
8
|
+
// React Native
|
|
6
9
|
#include <cxxreact/CxxModule.h>
|
|
7
|
-
#include "IWebSocketResource.h"
|
|
8
10
|
|
|
9
11
|
namespace Microsoft::React {
|
|
10
12
|
|
|
@@ -25,12 +27,12 @@ class WebSocketModule : public facebook::xplat::module::CxxModule {
|
|
|
25
27
|
/// Keeps <c>IWebSocketResource</c> instances identified by <c>id</c>.
|
|
26
28
|
/// As defined in WebSocket.js.
|
|
27
29
|
/// </summary>
|
|
28
|
-
std::map<int64_t, std::shared_ptr<IWebSocketResource>> ResourceMap{};
|
|
30
|
+
std::map<int64_t, std::shared_ptr<Networking::IWebSocketResource>> ResourceMap{};
|
|
29
31
|
|
|
30
32
|
/// <summary>
|
|
31
33
|
/// Generates IWebSocketResource instances, defaulting to IWebSocketResource::Make.
|
|
32
34
|
/// </summary>
|
|
33
|
-
std::function<std::shared_ptr<IWebSocketResource>(std::string &&)> ResourceFactory;
|
|
35
|
+
std::function<std::shared_ptr<Networking::IWebSocketResource>(std::string &&)> ResourceFactory;
|
|
34
36
|
|
|
35
37
|
/// <summary>
|
|
36
38
|
/// Keeps a raw reference to the module object to lazily retrieve the React Instance as needed.
|
|
@@ -58,14 +60,15 @@ class WebSocketModule : public facebook::xplat::module::CxxModule {
|
|
|
58
60
|
|
|
59
61
|
#pragma endregion CxxModule overrides
|
|
60
62
|
|
|
61
|
-
void SetResourceFactory(
|
|
63
|
+
void SetResourceFactory(
|
|
64
|
+
std::function<std::shared_ptr<Networking::IWebSocketResource>(const std::string &)> &&resourceFactory);
|
|
62
65
|
|
|
63
66
|
private:
|
|
64
67
|
/// <summary>
|
|
65
68
|
/// Keeps <c>IWebSocketResource</c> instances identified by <c>id</c>.
|
|
66
69
|
/// As defined in WebSocket.js.
|
|
67
70
|
/// </summary>
|
|
68
|
-
std::map<int64_t, std::shared_ptr<IWebSocketResource>> m_webSockets;
|
|
71
|
+
std::map<int64_t, std::shared_ptr<Networking::IWebSocketResource>> m_webSockets;
|
|
69
72
|
|
|
70
73
|
/// <summary>
|
|
71
74
|
/// Keeps members that can be accessed threads other than this module's owner accessible.
|
|
@@ -9,7 +9,7 @@
|
|
|
9
9
|
#include <string>
|
|
10
10
|
#include <unordered_map>
|
|
11
11
|
|
|
12
|
-
namespace Microsoft::React {
|
|
12
|
+
namespace Microsoft::React::Networking {
|
|
13
13
|
|
|
14
14
|
struct IHttpResource {
|
|
15
15
|
typedef std::unordered_map<std::string, std::string> Headers;
|
|
@@ -21,8 +21,8 @@ struct IHttpResource {
|
|
|
21
21
|
|
|
22
22
|
struct Response {
|
|
23
23
|
int64_t StatusCode;
|
|
24
|
-
Headers Headers;
|
|
25
24
|
std::string Url;
|
|
25
|
+
Headers Headers;
|
|
26
26
|
};
|
|
27
27
|
|
|
28
28
|
static std::shared_ptr<IHttpResource> Make() noexcept;
|
|
@@ -43,11 +43,11 @@ struct IHttpResource {
|
|
|
43
43
|
|
|
44
44
|
virtual void ClearCookies() noexcept = 0;
|
|
45
45
|
|
|
46
|
-
virtual void SetOnRequest(std::function<void(int64_t requestId)> &&handler) noexcept = 0;
|
|
46
|
+
virtual void SetOnRequest(std::function<void(int64_t requestId)> &&handler) noexcept = 0;
|
|
47
47
|
virtual void SetOnResponse(std::function<void(int64_t requestId, Response &&response)> &&handler) noexcept = 0;
|
|
48
48
|
virtual void SetOnData(std::function<void(int64_t requestId, std::string &&responseData)> &&handler) noexcept = 0;
|
|
49
49
|
virtual void SetOnError(
|
|
50
50
|
std::function<void(int64_t requestId, std::string &&errorMessage /*, bool isTimeout*/)> &&handler) noexcept = 0;
|
|
51
51
|
};
|
|
52
52
|
|
|
53
|
-
} // namespace Microsoft::React
|
|
53
|
+
} // namespace Microsoft::React::Networking
|
|
@@ -8,7 +8,7 @@
|
|
|
8
8
|
#include <string>
|
|
9
9
|
#include <vector>
|
|
10
10
|
|
|
11
|
-
namespace Microsoft::React {
|
|
11
|
+
namespace Microsoft::React::Networking {
|
|
12
12
|
|
|
13
13
|
/// <summary>
|
|
14
14
|
/// Defines the core functionality for a native WebSocket client resource.
|
|
@@ -181,4 +181,4 @@ struct IWebSocketResource {
|
|
|
181
181
|
virtual void SetOnError(std::function<void(Error &&)> &&handler) noexcept = 0;
|
|
182
182
|
};
|
|
183
183
|
|
|
184
|
-
} // namespace Microsoft::React
|
|
184
|
+
} // namespace Microsoft::React::Networking
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
// Copyright (c) Microsoft Corporation.
|
|
2
|
+
// Licensed under the MIT License.
|
|
3
|
+
|
|
4
|
+
#pragma once
|
|
5
|
+
|
|
6
|
+
namespace Microsoft::React::Networking {
|
|
7
|
+
|
|
8
|
+
enum class OriginPolicy : size_t {
|
|
9
|
+
None = 0,
|
|
10
|
+
SameOrigin = 1,
|
|
11
|
+
SimpleCrossOriginResourceSharing = 2,
|
|
12
|
+
CrossOriginResourceSharing = 3, // TODO: Rename as FullCrossOriginResourceSharing?
|
|
13
|
+
};
|
|
14
|
+
|
|
15
|
+
} // namespace Microsoft::React::Networking
|