2015-04-19 12:55:46 -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-04-02 07:33:21 -07:00
|
|
|
|
|
|
|
#import <UIKit/UIKit.h>
|
|
|
|
|
2016-11-01 10:14:00 -07:00
|
|
|
#import "RCTDefines.h"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* RCTScriptTag
|
|
|
|
*
|
|
|
|
* Scripts given to the JS Executors to run could be in any of the following
|
|
|
|
* formats. They are tagged so the executor knows how to run them.
|
|
|
|
*/
|
|
|
|
typedef NS_ENUM(NSInteger) {
|
|
|
|
RCTScriptString = 0,
|
|
|
|
RCTScriptRAMBundle,
|
|
|
|
RCTScriptBCBundle,
|
|
|
|
} RCTScriptTag;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* RCTMagicNumber
|
|
|
|
*
|
|
|
|
* RAM bundles and BC bundles begin with magic numbers. For RAM bundles this is
|
|
|
|
* 4 bytes, for BC bundles this is 8 bytes. This structure holds the first 8
|
|
|
|
* bytes from a bundle in a way that gives access to that information.
|
|
|
|
*/
|
|
|
|
typedef union {
|
|
|
|
uint64_t allBytes;
|
|
|
|
uint32_t first4;
|
|
|
|
uint64_t first8;
|
|
|
|
} RCTMagicNumber;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* RCTParseMagicNumber
|
|
|
|
*
|
|
|
|
* Takes the first 8 bytes of a bundle, and returns a tag describing the
|
|
|
|
* bundle's format.
|
|
|
|
*/
|
|
|
|
RCT_EXTERN RCTScriptTag RCTParseMagicNumber(RCTMagicNumber magic);
|
2016-03-17 10:34:46 -07:00
|
|
|
|
2016-07-12 05:13:32 -07:00
|
|
|
extern NSString *const RCTJavaScriptLoaderErrorDomain;
|
|
|
|
|
|
|
|
NS_ENUM(NSInteger) {
|
|
|
|
RCTJavaScriptLoaderErrorNoScriptURL = 1,
|
|
|
|
RCTJavaScriptLoaderErrorFailedOpeningFile = 2,
|
|
|
|
RCTJavaScriptLoaderErrorFailedReadingFile = 3,
|
|
|
|
RCTJavaScriptLoaderErrorFailedStatingFile = 3,
|
|
|
|
RCTJavaScriptLoaderErrorURLLoadFailed = 3,
|
|
|
|
|
|
|
|
RCTJavaScriptLoaderErrorCannotBeLoadedSynchronously = 1000,
|
|
|
|
};
|
|
|
|
|
2016-10-13 11:42:30 -07:00
|
|
|
@interface RCTLoadingProgress : NSObject
|
|
|
|
|
|
|
|
@property (nonatomic, copy) NSString *status;
|
|
|
|
@property (strong, nonatomic) NSNumber *done;
|
|
|
|
@property (strong, nonatomic) NSNumber *total;
|
|
|
|
|
|
|
|
@end
|
|
|
|
|
|
|
|
typedef void (^RCTSourceLoadProgressBlock)(RCTLoadingProgress *progressData);
|
2016-07-12 05:13:34 -07:00
|
|
|
typedef void (^RCTSourceLoadBlock)(NSError *error, NSData *source, int64_t sourceLength);
|
2015-04-02 07:33:21 -07:00
|
|
|
|
|
|
|
@interface RCTJavaScriptLoader : NSObject
|
|
|
|
|
2016-10-13 11:42:30 -07:00
|
|
|
+ (void)loadBundleAtURL:(NSURL *)scriptURL onProgress:(RCTSourceLoadProgressBlock)onProgress onComplete:(RCTSourceLoadBlock)onComplete;
|
2016-07-12 05:13:32 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @experimental
|
|
|
|
* Attempts to synchronously load the script at the given URL. The following two conditions must be met:
|
2016-07-13 16:39:15 -07:00
|
|
|
* 1. It must be a file URL.
|
2016-11-01 10:14:00 -07:00
|
|
|
* 2. It must not point to a text/javascript file.
|
2016-07-12 05:13:32 -07:00
|
|
|
* If the URL does not meet those conditions, this method will return nil and supply an error with the domain
|
|
|
|
* RCTJavaScriptLoaderErrorDomain and the code RCTJavaScriptLoaderErrorCannotBeLoadedSynchronously.
|
|
|
|
*/
|
|
|
|
+ (NSData *)attemptSynchronousLoadOfBundleAtURL:(NSURL *)scriptURL
|
|
|
|
sourceLength:(int64_t *)sourceLength
|
|
|
|
error:(NSError **)error;
|
2015-04-02 07:33:21 -07:00
|
|
|
|
|
|
|
@end
|