2016-11-15 17:28:10 +00:00
|
|
|
/**
|
|
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
|
|
|
*
|
2018-02-17 02:24:55 +00:00
|
|
|
* This source code is licensed under the MIT license found in the
|
|
|
|
* LICENSE file in the root directory of this source tree.
|
2016-11-15 17:28:10 +00:00
|
|
|
*/
|
|
|
|
|
2017-04-18 20:15:25 +00:00
|
|
|
#import "RCTJSCSamplingProfiler.h"
|
2016-11-15 17:28:10 +00:00
|
|
|
|
|
|
|
#import "RCTBridge.h"
|
|
|
|
#import "RCTLog.h"
|
|
|
|
|
2017-04-18 20:15:25 +00:00
|
|
|
@implementation RCTJSCSamplingProfiler
|
2016-11-15 17:28:10 +00:00
|
|
|
|
|
|
|
@synthesize methodQueue = _methodQueue;
|
|
|
|
@synthesize bridge = _bridge;
|
|
|
|
|
2017-04-18 20:15:25 +00:00
|
|
|
RCT_EXPORT_MODULE(RCTJSCSamplingProfiler);
|
2016-11-15 17:28:10 +00:00
|
|
|
|
|
|
|
#ifdef RCT_PROFILE
|
2017-01-10 03:23:44 +00:00
|
|
|
RCT_EXPORT_METHOD(operationComplete:(__unused int)token result:(id)profileData error:(id)error)
|
2016-11-15 17:28:10 +00:00
|
|
|
{
|
|
|
|
if (error) {
|
|
|
|
RCTLogError(@"JSC Sampling profiler ended with error: %@", error);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Create a POST request with all of the datas
|
|
|
|
NSURL *url = [NSURL URLWithString:@"/jsc-profile" relativeToURL:self.bridge.bundleURL];
|
|
|
|
NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL:url
|
|
|
|
cachePolicy:NSURLRequestReloadIgnoringLocalAndRemoteCacheData
|
|
|
|
timeoutInterval:60];
|
|
|
|
[request setHTTPMethod:@"POST"];
|
|
|
|
[request setHTTPBody:[profileData dataUsingEncoding:NSUTF8StringEncoding]];
|
|
|
|
|
|
|
|
// Send the request
|
2017-01-10 19:19:09 +00:00
|
|
|
NSURLSession *session = [NSURLSession sessionWithConfiguration:[NSURLSessionConfiguration defaultSessionConfiguration]];
|
2017-01-13 20:30:29 +00:00
|
|
|
NSURLSessionDataTask *sessionDataTask = [session dataTaskWithRequest:request completionHandler:^(__unused NSData *data, __unused NSURLResponse *response, NSError *sessionError) {
|
2017-01-10 19:19:09 +00:00
|
|
|
if (sessionError) {
|
|
|
|
RCTLogWarn(@"JS CPU Profile data failed to send. Is the packager server running locally?\nDetails: %@", error);
|
|
|
|
} else {
|
|
|
|
RCTLogInfo(@"JS CPU Profile data sent successfully.");
|
|
|
|
}
|
|
|
|
}];
|
|
|
|
|
|
|
|
[sessionDataTask resume];
|
2016-11-15 17:28:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
- (void)operationCompletedWithResults:(NSString *)results
|
|
|
|
{
|
|
|
|
// Send the results to the packager, using the module's queue.
|
|
|
|
dispatch_async(self.methodQueue, ^{
|
|
|
|
[self operationComplete:0 result:results error:nil];
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
@end
|