Reduced module config data

Summary: public

We're sending a lot of module config data when the app first starts, and much of this is redundant.

UIExplorer current sends 19061 bytes of module config JSON. This diff reduces that to 16104 (15% saving) by stripping modules that have no methods or constants, and removing method types unless method is async.

Reviewed By: tadeuzagallo, javache

Differential Revision: D2570010

fb-gh-sync-id: 8c0abbd1cdee3264b37a4f52e852008caaffb9c5
This commit is contained in:
Nick Lockwood 2015-10-22 05:51:21 -07:00 committed by facebook-github-bot-4
parent 66717d802b
commit ae5de54f00
3 changed files with 30 additions and 11 deletions

View File

@ -186,7 +186,7 @@ class MessageQueue {
let moduleNames = Object.keys(localModules); let moduleNames = Object.keys(localModules);
for (var i = 0, l = moduleNames.length; i < l; i++) { for (var i = 0, l = moduleNames.length; i < l; i++) {
let moduleName = moduleNames[i]; let moduleName = moduleNames[i];
let methods = localModules[moduleName].methods; let methods = localModules[moduleName].methods || {};
let moduleID = localModules[moduleName].moduleID; let moduleID = localModules[moduleName].moduleID;
moduleTable[moduleID] = moduleName; moduleTable[moduleID] = moduleName;
methodTable[moduleID] = {}; methodTable[moduleID] = {};
@ -210,12 +210,16 @@ class MessageQueue {
} }
_genModule(module, moduleConfig) { _genModule(module, moduleConfig) {
let methodNames = Object.keys(moduleConfig.methods); let methods = moduleConfig.methods || {};
let methodNames = Object.keys(methods);
for (var i = 0, l = methodNames.length; i < l; i++) { for (var i = 0, l = methodNames.length; i < l; i++) {
let methodName = methodNames[i]; let methodName = methodNames[i];
let methodConfig = moduleConfig.methods[methodName]; let methodConfig = methods[methodName];
module[methodName] = this._genMethod( module[methodName] = this._genMethod(
moduleConfig.moduleID, methodConfig.methodID, methodConfig.type); moduleConfig.moduleID,
methodConfig.methodID,
methodConfig.type || MethodTypes.remote
);
} }
Object.assign(module, moduleConfig.constants); Object.assign(module, moduleConfig.constants);
return module; return module;
@ -260,7 +264,7 @@ class MessageQueue {
} }
function createErrorFromErrorData(errorData: ErrorData): Error { function createErrorFromErrorData(errorData: {message: string}): Error {
var { var {
message, message,
...extraErrorInfo, ...extraErrorInfo,

View File

@ -310,7 +310,10 @@ RCT_EXTERN NSArray *RCTGetModuleClasses(void);
{ {
NSMutableDictionary *config = [NSMutableDictionary new]; NSMutableDictionary *config = [NSMutableDictionary new];
for (RCTModuleData *moduleData in _moduleDataByID) { for (RCTModuleData *moduleData in _moduleDataByID) {
config[moduleData.name] = moduleData.config; NSDictionary *moduleConfig = moduleData.config;
if (moduleConfig) {
config[moduleData.name] = moduleConfig;
}
if ([moduleData.instance conformsToProtocol:@protocol(RCTFrameUpdateObserver)]) { if ([moduleData.instance conformsToProtocol:@protocol(RCTFrameUpdateObserver)]) {
[_frameUpdateObservers addObject:moduleData]; [_frameUpdateObservers addObject:moduleData];

View File

@ -81,6 +81,10 @@ RCT_NOT_IMPLEMENTED(- (instancetype)init);
- (NSDictionary *)config - (NSDictionary *)config
{ {
if (_constants.count == 0 && self.methods.count == 0) {
return nil; // Nothing to export
}
NSMutableDictionary *config = [NSMutableDictionary new]; NSMutableDictionary *config = [NSMutableDictionary new];
config[@"moduleID"] = _moduleID; config[@"moduleID"] = _moduleID;
@ -90,12 +94,20 @@ RCT_NOT_IMPLEMENTED(- (instancetype)init);
NSMutableDictionary *methodconfig = [NSMutableDictionary new]; NSMutableDictionary *methodconfig = [NSMutableDictionary new];
[self.methods enumerateObjectsUsingBlock:^(id<RCTBridgeMethod> method, NSUInteger idx, __unused BOOL *stop) { [self.methods enumerateObjectsUsingBlock:^(id<RCTBridgeMethod> method, NSUInteger idx, __unused BOOL *stop) {
methodconfig[method.JSMethodName] = @{ if (method.functionType == RCTFunctionTypePromise) {
@"methodID": @(idx), methodconfig[method.JSMethodName] = @{
@"type": method.functionType == RCTFunctionTypePromise ? @"remoteAsync" : @"remote", @"methodID": @(idx),
}; @"type": @"remoteAsync",
};
} else {
methodconfig[method.JSMethodName] = @{
@"methodID": @(idx),
};
}
}]; }];
config[@"methods"] = [methodconfig copy]; if (methodconfig.count) {
config[@"methods"] = [methodconfig copy];
}
return [config copy]; return [config copy];
} }