mirror of
https://github.com/facebook/react-native.git
synced 2025-11-01 09:14:26 +00:00
3724810d21
Summary: This PR adds initial support for Project Catalyst a.k.a. UIKitForMac. This is not yet meant for production, but this is enough for RNTester to successfully compile and mostly work :) Some APIs are not supported on the Mac -- e.g. telephony, and deprecated APIs are removed on Mac ���-- those had to be ifdef'd out via platform checks. The biggest limitation right now is that I couldn't get Web Socket code to successfully compile, and so there are a lot of temporary platform checks for that , and the RCTWebSocket.xcodeproj is marked as not supporting UIKitForMac. Again -- temporary, until someone with more knowledge knows how to fix this. https://github.com/react-native-community/discussions-and-proposals/issues/131 ## Changelog [iOS] [Added] - Fixed compilation for macOS (Project Catalyst) -- not meant for production use yet Pull Request resolved: https://github.com/facebook/react-native/pull/25427 Test Plan: - Open RNTester/RNTester.xcodeproj with Xcode 10.2, run it like a normal iOS app -- make sure it compiles and runs correctly (no regression) - Open the same project with Xcode 11 beta 2 (or higher) on macOS Catalina beta, select "My Mac" as device target, and run -- see that it actually compiles and runs. **Note** there are unfortunately some required steps: - change build configuration to Release (because packager doesn't work correctly yet) - change development team to yours if Xcode tells you to - go to RNTester project → Build phases → Link binary with libraries, and change `platforms` for `libRCTWebSocket.a` to `iOS` (without Mac compatibility). I can't commit that change because it breaks compatibility with earlier Xcode versions The two extra steps for successful compile will disappear once web socket compilation for Catalyst is fixed Reviewed By: mmmulani Differential Revision: D16088263 Pulled By: sammy-SC fbshipit-source-id: 9c0b932b048e50a8e0f336eaa0612851b1909cae
77 lines
2.7 KiB
Objective-C
77 lines
2.7 KiB
Objective-C
/**
|
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*/
|
|
|
|
#import <Foundation/Foundation.h>
|
|
|
|
#import <React/RCTDefines.h>
|
|
|
|
#if RCT_DEV && !TARGET_OS_UIKITFORMAC
|
|
|
|
NS_ASSUME_NONNULL_BEGIN
|
|
|
|
@protocol RCTPackagerClientMethod;
|
|
@class RCTPackagerClientResponder;
|
|
|
|
typedef uint32_t RCTHandlerToken;
|
|
typedef void (^RCTNotificationHandler)(NSDictionary<NSString *, id> *);
|
|
typedef void (^RCTRequestHandler)(NSDictionary<NSString *, id> *, RCTPackagerClientResponder *);
|
|
typedef void (^RCTConnectedHandler)(void);
|
|
|
|
/** Encapsulates singleton connection to React Native packager. */
|
|
@interface RCTPackagerConnection : NSObject
|
|
|
|
+ (instancetype)sharedPackagerConnection;
|
|
|
|
/**
|
|
* Registers a handler for a notification broadcast from the packager. An
|
|
* example is "reload" - an instruction to reload from the packager.
|
|
* If multiple notification handlers are registered for the same method, they
|
|
* will all be invoked sequentially.
|
|
*/
|
|
- (RCTHandlerToken)addNotificationHandler:(RCTNotificationHandler)handler
|
|
queue:(dispatch_queue_t)queue
|
|
forMethod:(NSString *)method;
|
|
|
|
/**
|
|
* Registers a handler for a request from the packager. An example is
|
|
* pokeSamplingProfiler; it asks for profile data from the client.
|
|
* Only one handler can be registered for a given method; calling this
|
|
* displaces any previous request handler registered for that method.
|
|
*/
|
|
- (RCTHandlerToken)addRequestHandler:(RCTRequestHandler)handler
|
|
queue:(dispatch_queue_t)queue
|
|
forMethod:(NSString *)method;
|
|
|
|
/**
|
|
* Registers a handler that runs at most once, when the connection to the
|
|
* packager has been established. The handler will be dispatched immediately
|
|
* if the connection is already established.
|
|
*/
|
|
- (RCTHandlerToken)addConnectedHandler:(RCTConnectedHandler)handler
|
|
queue:(dispatch_queue_t)queue;
|
|
|
|
/** Removes a handler. Silently does nothing if the token is not valid. */
|
|
- (void)removeHandler:(RCTHandlerToken)token;
|
|
|
|
/** Disconnects and removes all handlers. */
|
|
- (void)stop;
|
|
|
|
/**
|
|
* Historically no distinction was made between notification and request
|
|
* handlers. If you use this method, it will be registered as *both* a
|
|
* notification handler *and* a request handler. You should migrate to the
|
|
* new block-based API instead.
|
|
*/
|
|
- (void)addHandler:(id<RCTPackagerClientMethod>)handler
|
|
forMethod:(NSString *)method __deprecated_msg("Use addRequestHandler or addNotificationHandler instead");
|
|
|
|
@end
|
|
|
|
NS_ASSUME_NONNULL_END
|
|
|
|
#endif
|