2015-03-23 13:28:42 -07:00
|
|
|
/**
|
|
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* This source code is licensed under the BSD-style license found in the
|
|
|
|
* LICENSE file in the root directory of this source tree. An additional grant
|
|
|
|
* of patent rights can be found in the PATENTS file in the same directory.
|
|
|
|
*/
|
2015-02-19 20:10:52 -08:00
|
|
|
|
2015-04-13 10:22:11 -07:00
|
|
|
#import <objc/message.h>
|
|
|
|
|
2015-02-19 20:10:52 -08:00
|
|
|
#import <QuartzCore/QuartzCore.h>
|
|
|
|
#import <UIKit/UIKit.h>
|
|
|
|
|
2015-03-26 14:22:12 +00:00
|
|
|
#import "../Layout/Layout.h"
|
|
|
|
#import "../Views/RCTAnimationType.h"
|
|
|
|
#import "../Views/RCTPointerEvents.h"
|
|
|
|
|
2015-03-25 16:22:59 -07:00
|
|
|
#import "RCTLog.h"
|
2015-02-19 20:10:52 -08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* This class provides a collection of conversion functions for mapping
|
|
|
|
* JSON objects to native types and classes. These are useful when writing
|
|
|
|
* custom RCTViewManager setter methods.
|
|
|
|
*/
|
|
|
|
@interface RCTConvert : NSObject
|
|
|
|
|
|
|
|
+ (BOOL)BOOL:(id)json;
|
|
|
|
+ (double)double:(id)json;
|
|
|
|
+ (float)float:(id)json;
|
|
|
|
+ (int)int:(id)json;
|
|
|
|
|
2015-03-24 17:37:03 -07:00
|
|
|
+ (int64_t)int64_t:(id)json;
|
|
|
|
+ (uint64_t)uint64_t:(id)json;
|
|
|
|
|
2015-03-10 19:03:59 -07:00
|
|
|
+ (NSInteger)NSInteger:(id)json;
|
|
|
|
+ (NSUInteger)NSUInteger:(id)json;
|
|
|
|
|
2015-03-09 03:04:44 -07:00
|
|
|
+ (NSArray *)NSArray:(id)json;
|
|
|
|
+ (NSDictionary *)NSDictionary:(id)json;
|
2015-02-19 20:10:52 -08:00
|
|
|
+ (NSString *)NSString:(id)json;
|
|
|
|
+ (NSNumber *)NSNumber:(id)json;
|
2015-04-09 20:18:31 -07:00
|
|
|
+ (NSData *)NSData:(id)json;
|
2015-02-19 20:10:52 -08:00
|
|
|
|
|
|
|
+ (NSURL *)NSURL:(id)json;
|
|
|
|
+ (NSURLRequest *)NSURLRequest:(id)json;
|
|
|
|
|
|
|
|
+ (NSDate *)NSDate:(id)json;
|
|
|
|
+ (NSTimeZone *)NSTimeZone:(id)json;
|
|
|
|
+ (NSTimeInterval)NSTimeInterval:(id)json;
|
|
|
|
|
|
|
|
+ (NSTextAlignment)NSTextAlignment:(id)json;
|
|
|
|
+ (NSWritingDirection)NSWritingDirection:(id)json;
|
2015-03-17 07:04:39 -07:00
|
|
|
+ (UITextAutocapitalizationType)UITextAutocapitalizationType:(id)json;
|
2015-03-25 21:29:28 -07:00
|
|
|
+ (UITextFieldViewMode)UITextFieldViewMode:(id)json;
|
|
|
|
+ (UIScrollViewKeyboardDismissMode)UIScrollViewKeyboardDismissMode:(id)json;
|
2015-02-19 20:10:52 -08:00
|
|
|
+ (UIKeyboardType)UIKeyboardType:(id)json;
|
2015-03-30 18:25:30 -07:00
|
|
|
+ (UIReturnKeyType)UIReturnKeyType:(id)json;
|
2015-02-19 20:10:52 -08:00
|
|
|
|
2015-03-25 21:29:28 -07:00
|
|
|
+ (UIViewContentMode)UIViewContentMode:(id)json;
|
|
|
|
+ (UIBarStyle)UIBarStyle:(id)json;
|
|
|
|
|
2015-02-19 20:10:52 -08:00
|
|
|
+ (CGFloat)CGFloat:(id)json;
|
|
|
|
+ (CGPoint)CGPoint:(id)json;
|
|
|
|
+ (CGSize)CGSize:(id)json;
|
|
|
|
+ (CGRect)CGRect:(id)json;
|
|
|
|
+ (UIEdgeInsets)UIEdgeInsets:(id)json;
|
|
|
|
|
2015-03-15 16:08:42 -07:00
|
|
|
+ (CGLineCap)CGLineCap:(id)json;
|
|
|
|
+ (CGLineJoin)CGLineJoin:(id)json;
|
|
|
|
|
2015-02-19 20:10:52 -08:00
|
|
|
+ (CATransform3D)CATransform3D:(id)json;
|
|
|
|
+ (CGAffineTransform)CGAffineTransform:(id)json;
|
|
|
|
|
|
|
|
+ (UIColor *)UIColor:(id)json;
|
|
|
|
+ (CGColorRef)CGColor:(id)json;
|
|
|
|
|
|
|
|
+ (UIImage *)UIImage:(id)json;
|
|
|
|
+ (CGImageRef)CGImage:(id)json;
|
|
|
|
|
|
|
|
+ (UIFont *)UIFont:(UIFont *)font withSize:(id)json;
|
|
|
|
+ (UIFont *)UIFont:(UIFont *)font withWeight:(id)json;
|
2015-03-25 16:22:59 -07:00
|
|
|
+ (UIFont *)UIFont:(UIFont *)font withStyle:(id)json;
|
2015-02-19 20:10:52 -08:00
|
|
|
+ (UIFont *)UIFont:(UIFont *)font withFamily:(id)json;
|
2015-03-25 21:29:28 -07:00
|
|
|
+ (UIFont *)UIFont:(UIFont *)font withFamily:(id)family
|
|
|
|
size:(id)size weight:(id)weight style:(id)style;
|
2015-02-19 20:10:52 -08:00
|
|
|
|
2015-04-08 08:52:48 -07:00
|
|
|
typedef NSArray NSStringArray;
|
|
|
|
+ (NSStringArray *)NSStringArray:(id)json;
|
|
|
|
|
|
|
|
typedef NSArray NSDictionaryArray;
|
|
|
|
+ (NSDictionaryArray *)NSDictionaryArray:(id)json;
|
|
|
|
|
|
|
|
typedef NSArray NSURLArray;
|
|
|
|
+ (NSURLArray *)NSURLArray:(id)json;
|
|
|
|
|
|
|
|
typedef NSArray NSNumberArray;
|
|
|
|
+ (NSNumberArray *)NSNumberArray:(id)json;
|
|
|
|
|
|
|
|
typedef NSArray UIColorArray;
|
|
|
|
+ (UIColorArray *)UIColorArray:(id)json;
|
|
|
|
|
|
|
|
typedef NSArray CGColorArray;
|
|
|
|
+ (CGColorArray *)CGColorArray:(id)json;
|
|
|
|
|
|
|
|
typedef BOOL css_overflow;
|
|
|
|
+ (css_overflow)css_overflow:(id)json;
|
2015-02-19 20:10:52 -08:00
|
|
|
+ (css_flex_direction_t)css_flex_direction_t:(id)json;
|
|
|
|
+ (css_justify_t)css_justify_t:(id)json;
|
|
|
|
+ (css_align_t)css_align_t:(id)json;
|
|
|
|
+ (css_position_type_t)css_position_type_t:(id)json;
|
|
|
|
+ (css_wrap_type_t)css_wrap_type_t:(id)json;
|
|
|
|
|
|
|
|
+ (RCTPointerEvents)RCTPointerEvents:(id)json;
|
|
|
|
+ (RCTAnimationType)RCTAnimationType:(id)json;
|
|
|
|
|
|
|
|
@end
|
|
|
|
|
2015-03-05 16:36:41 -08:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2015-02-19 20:10:52 -08:00
|
|
|
/**
|
|
|
|
* This function will attempt to set a property using a json value by first
|
|
|
|
* inferring the correct type from all available information, and then
|
|
|
|
* applying an appropriate conversion method. If the property does not
|
|
|
|
* exist, or the type cannot be inferred, the function will return NO.
|
|
|
|
*/
|
2015-03-25 21:29:28 -07:00
|
|
|
BOOL RCTSetProperty(id target, NSString *keyPath, SEL type, id json);
|
2015-02-19 20:10:52 -08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* This function attempts to copy a property from the source object to the
|
|
|
|
* destination object using KVC. If the property does not exist, or cannot
|
|
|
|
* be set, it will do nothing and return NO.
|
|
|
|
*/
|
2015-03-25 21:29:28 -07:00
|
|
|
BOOL RCTCopyProperty(id target, id source, NSString *keyPath);
|
2015-03-10 14:23:03 -07:00
|
|
|
|
[Bridge] `RCT_REMAP_METHOD(js_name, selector)`
Summary:
cc @a2 @nicklockwood
This diff introduces a new macro called `RCT_EXPORT_NAMED_METHOD`, which is like `RCT_EXPORT_METHOD` but lets you choose the name of the method in JS. This diff is backwards compatible with the `RCT_EXPORT_METHOD` and legacy `RCT_EXPORT` macros.
The entries in the data segment now contain `__func__`, the Obj-C selector signature, and the JS name. If the JS name is `NULL`, we take the legacy `RCT_EXPORT` code path. If the JS name is an empty string, we use the Obj-C selector's name up to the first colon (that is, the behavior of `RCT_EXPORT_METHOD`).
Since there are three values in each data segment entry, the macros now specify 1-byte alignment. Without the byte alignment, the compiler defaults to 2-byte alignment meaning that each entry takes up 4 bytes instead of 3. The extra byte isn't a concern but being explicit about the alignment should reduce compiler surprises.
Closes https://github.com/facebook/react-native/pull/802
Github Author: James Ide <ide@jameside.com>
Test Plan: Imported from GitHub, without a `Test Plan:` line.
2015-04-14 13:03:16 -07:00
|
|
|
/**
|
|
|
|
* Underlying implementation of RCT_ENUM_CONVERTER macro. Ignore this.
|
|
|
|
*/
|
2015-04-18 10:43:20 -07:00
|
|
|
NSNumber *RCTConvertEnumValue(const char *, NSDictionary *, NSNumber *, id);
|
[Bridge] `RCT_REMAP_METHOD(js_name, selector)`
Summary:
cc @a2 @nicklockwood
This diff introduces a new macro called `RCT_EXPORT_NAMED_METHOD`, which is like `RCT_EXPORT_METHOD` but lets you choose the name of the method in JS. This diff is backwards compatible with the `RCT_EXPORT_METHOD` and legacy `RCT_EXPORT` macros.
The entries in the data segment now contain `__func__`, the Obj-C selector signature, and the JS name. If the JS name is `NULL`, we take the legacy `RCT_EXPORT` code path. If the JS name is an empty string, we use the Obj-C selector's name up to the first colon (that is, the behavior of `RCT_EXPORT_METHOD`).
Since there are three values in each data segment entry, the macros now specify 1-byte alignment. Without the byte alignment, the compiler defaults to 2-byte alignment meaning that each entry takes up 4 bytes instead of 3. The extra byte isn't a concern but being explicit about the alignment should reduce compiler surprises.
Closes https://github.com/facebook/react-native/pull/802
Github Author: James Ide <ide@jameside.com>
Test Plan: Imported from GitHub, without a `Test Plan:` line.
2015-04-14 13:03:16 -07:00
|
|
|
|
2015-03-05 16:36:41 -08:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
2015-03-15 16:08:42 -07:00
|
|
|
|
2015-03-30 06:07:07 -07:00
|
|
|
/**
|
|
|
|
* This macro is used for creating simple converter functions that just call
|
|
|
|
* the specified getter method on the json value.
|
|
|
|
*/
|
|
|
|
#define RCT_CONVERTER(type, name, getter) \
|
|
|
|
RCT_CUSTOM_CONVERTER(type, name, [json getter])
|
|
|
|
|
2015-03-15 16:08:42 -07:00
|
|
|
/**
|
|
|
|
* This macro is used for creating converter functions with arbitrary logic.
|
|
|
|
*/
|
2015-03-30 06:07:07 -07:00
|
|
|
#define RCT_CUSTOM_CONVERTER(type, name, code) \
|
2015-03-15 16:08:42 -07:00
|
|
|
+ (type)name:(id)json \
|
|
|
|
{ \
|
|
|
|
if (json == [NSNull null]) { \
|
|
|
|
json = nil; \
|
|
|
|
} \
|
|
|
|
@try { \
|
|
|
|
return code; \
|
|
|
|
} \
|
|
|
|
@catch (__unused NSException *e) { \
|
|
|
|
RCTLogError(@"JSON value '%@' of type '%@' cannot be converted to '%s'", \
|
2015-04-07 07:36:26 -07:00
|
|
|
json, [json classForCoder], #type); \
|
2015-03-15 16:08:42 -07:00
|
|
|
json = nil; \
|
|
|
|
return code; \
|
|
|
|
} \
|
|
|
|
}
|
|
|
|
|
2015-03-24 17:37:03 -07:00
|
|
|
/**
|
|
|
|
* This macro is similar to RCT_CONVERTER, but specifically geared towards
|
|
|
|
* numeric types. It will handle string input correctly, and provides more
|
[Bridge] `RCT_REMAP_METHOD(js_name, selector)`
Summary:
cc @a2 @nicklockwood
This diff introduces a new macro called `RCT_EXPORT_NAMED_METHOD`, which is like `RCT_EXPORT_METHOD` but lets you choose the name of the method in JS. This diff is backwards compatible with the `RCT_EXPORT_METHOD` and legacy `RCT_EXPORT` macros.
The entries in the data segment now contain `__func__`, the Obj-C selector signature, and the JS name. If the JS name is `NULL`, we take the legacy `RCT_EXPORT` code path. If the JS name is an empty string, we use the Obj-C selector's name up to the first colon (that is, the behavior of `RCT_EXPORT_METHOD`).
Since there are three values in each data segment entry, the macros now specify 1-byte alignment. Without the byte alignment, the compiler defaults to 2-byte alignment meaning that each entry takes up 4 bytes instead of 3. The extra byte isn't a concern but being explicit about the alignment should reduce compiler surprises.
Closes https://github.com/facebook/react-native/pull/802
Github Author: James Ide <ide@jameside.com>
Test Plan: Imported from GitHub, without a `Test Plan:` line.
2015-04-14 13:03:16 -07:00
|
|
|
* detailed error reporting if an invalid value is passed in.
|
2015-03-24 17:37:03 -07:00
|
|
|
*/
|
|
|
|
#define RCT_NUMBER_CONVERTER(type, getter) \
|
2015-03-30 06:07:07 -07:00
|
|
|
RCT_CUSTOM_CONVERTER(type, type, [[self NSNumber:json] getter])
|
2015-03-24 17:37:03 -07:00
|
|
|
|
2015-03-15 16:08:42 -07:00
|
|
|
/**
|
|
|
|
* This macro is used for creating converters for enum types.
|
|
|
|
*/
|
|
|
|
#define RCT_ENUM_CONVERTER(type, values, default, getter) \
|
|
|
|
+ (type)type:(id)json \
|
|
|
|
{ \
|
|
|
|
static NSDictionary *mapping; \
|
|
|
|
static dispatch_once_t onceToken; \
|
|
|
|
dispatch_once(&onceToken, ^{ \
|
|
|
|
mapping = values; \
|
|
|
|
}); \
|
2015-04-18 10:43:20 -07:00
|
|
|
NSNumber *converted = RCTConvertEnumValue(#type, mapping, @(default), json); \
|
2015-04-13 10:22:11 -07:00
|
|
|
return ((type(*)(id, SEL))objc_msgSend)(converted, @selector(getter)); \
|
2015-03-15 16:08:42 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This macro is used for creating converter functions for typed arrays.
|
|
|
|
*/
|
|
|
|
#define RCT_ARRAY_CONVERTER(type) \
|
2015-04-08 08:52:48 -07:00
|
|
|
+ (type##Array *)type##Array:(id)json \
|
2015-03-15 16:08:42 -07:00
|
|
|
{ \
|
|
|
|
NSMutableArray *values = [[NSMutableArray alloc] init]; \
|
|
|
|
for (id jsonValue in [self NSArray:json]) { \
|
|
|
|
id value = [self type:jsonValue]; \
|
|
|
|
if (value) { \
|
|
|
|
[values addObject:value]; \
|
|
|
|
} \
|
|
|
|
} \
|
|
|
|
return values; \
|
|
|
|
}
|