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-23 07:47:52 -08:00
|
|
|
#import <React/RCTDefines.h>
|
2016-11-01 10:14:00 -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,
|
2016-11-11 05:21:37 -08:00
|
|
|
RCTJavaScriptLoaderErrorBCVersion = 4,
|
2017-01-11 22:28:07 -08:00
|
|
|
RCTJavaScriptLoaderErrorBCNotSupported = 4,
|
2016-07-12 05:13:32 -07:00
|
|
|
|
|
|
|
RCTJavaScriptLoaderErrorCannotBeLoadedSynchronously = 1000,
|
|
|
|
};
|
|
|
|
|
2017-08-31 05:25:19 -07:00
|
|
|
NS_ENUM(NSInteger) {
|
|
|
|
RCTSourceFilesChangedCountNotBuiltByBundler = -2,
|
|
|
|
RCTSourceFilesChangedCountRebuiltFromScratch = -1,
|
|
|
|
};
|
|
|
|
|
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
|
|
|
|
|
2017-08-30 06:15:56 -07:00
|
|
|
@interface RCTSource : NSObject
|
|
|
|
|
|
|
|
/**
|
|
|
|
* URL of the source object.
|
|
|
|
*/
|
|
|
|
@property (strong, nonatomic, readonly) NSURL *url;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* JS source (or simply the binary header in the case of a RAM bundle).
|
|
|
|
*/
|
|
|
|
@property (strong, nonatomic, readonly) NSData *data;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Length of the entire JS bundle. Note that self.length != self.data.length in the case of certain bundle formats. For
|
|
|
|
* instance, when using RAM bundles:
|
|
|
|
*
|
|
|
|
* - self.data will point to the bundle header
|
|
|
|
* - self.data.length is the length of the bundle header, i.e. sizeof(facebook::react::BundleHeader)
|
|
|
|
* - self.length is the length of the entire bundle file (header + contents)
|
|
|
|
*/
|
|
|
|
@property (nonatomic, readonly) NSUInteger length;
|
|
|
|
|
2017-08-31 05:25:19 -07:00
|
|
|
/**
|
|
|
|
* Returns number of files changed when building this bundle:
|
|
|
|
*
|
|
|
|
* - RCTSourceFilesChangedCountNotBuiltByBundler if the source wasn't built by the bundler (e.g. read from disk)
|
|
|
|
* - RCTSourceFilesChangedCountRebuiltFromScratch if the source was rebuilt from scratch by the bundler
|
|
|
|
* - Otherwise, the number of files changed when incrementally rebuilding the source
|
|
|
|
*/
|
|
|
|
@property (nonatomic, readonly) NSInteger filesChangedCount;
|
|
|
|
|
2017-08-30 06:15:56 -07:00
|
|
|
@end
|
|
|
|
|
2016-10-13 11:42:30 -07:00
|
|
|
typedef void (^RCTSourceLoadProgressBlock)(RCTLoadingProgress *progressData);
|
2017-08-30 06:15:56 -07:00
|
|
|
typedef void (^RCTSourceLoadBlock)(NSError *error, RCTSource *source);
|
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
|
2016-11-11 05:21:37 -08:00
|
|
|
runtimeBCVersion:(int32_t)runtimeBCVersion
|
2016-07-12 05:13:32 -07:00
|
|
|
sourceLength:(int64_t *)sourceLength
|
|
|
|
error:(NSError **)error;
|
2015-04-02 07:33:21 -07:00
|
|
|
|
|
|
|
@end
|