mirror of
https://github.com/status-im/react-native.git
synced 2025-01-12 10:34:57 +00:00
Convert ReactPackages in FB4a to switch-case
Reviewed By: achen1 Differential Revision: D9511962 fbshipit-source-id: ea42b25f13b157866057d96d026317098e47ea63
This commit is contained in:
parent
0df92afc1c
commit
2f79960a69
@ -78,7 +78,6 @@ public abstract class LazyReactPackage implements ReactPackage {
|
|||||||
*/
|
*/
|
||||||
/* package */
|
/* package */
|
||||||
Iterable<ModuleHolder> getNativeModuleIterator(final ReactApplicationContext reactContext) {
|
Iterable<ModuleHolder> getNativeModuleIterator(final ReactApplicationContext reactContext) {
|
||||||
final List<String> eagerNativeModules = getEagerNativeModules();
|
|
||||||
final Map<String, ReactModuleInfo> reactModuleInfoMap =
|
final Map<String, ReactModuleInfo> reactModuleInfoMap =
|
||||||
getReactModuleInfoProvider().getReactModuleInfos();
|
getReactModuleInfoProvider().getReactModuleInfos();
|
||||||
final List<ModuleSpec> nativeModules = getNativeModules(reactContext);
|
final List<ModuleSpec> nativeModules = getNativeModules(reactContext);
|
||||||
@ -96,7 +95,7 @@ public abstract class LazyReactPackage implements ReactPackage {
|
|||||||
String name = moduleSpec.getName();
|
String name = moduleSpec.getName();
|
||||||
ReactModuleInfo reactModuleInfo = reactModuleInfoMap.get(name);
|
ReactModuleInfo reactModuleInfo = reactModuleInfoMap.get(name);
|
||||||
ModuleHolder moduleHolder;
|
ModuleHolder moduleHolder;
|
||||||
if (reactModuleInfo == null || eagerNativeModules.contains(name)) {
|
if (reactModuleInfo == null) {
|
||||||
NativeModule module;
|
NativeModule module;
|
||||||
ReactMarker.logMarker(ReactMarkerConstants.CREATE_MODULE_START, name);
|
ReactMarker.logMarker(ReactMarkerConstants.CREATE_MODULE_START, name);
|
||||||
try {
|
try {
|
||||||
@ -131,11 +130,6 @@ public abstract class LazyReactPackage implements ReactPackage {
|
|||||||
*/
|
*/
|
||||||
protected abstract List<ModuleSpec> getNativeModules(ReactApplicationContext reactContext);
|
protected abstract List<ModuleSpec> getNativeModules(ReactApplicationContext reactContext);
|
||||||
|
|
||||||
/** @return list of native modules which should be eagerly initialized. */
|
|
||||||
protected List<String> getEagerNativeModules() {
|
|
||||||
return Collections.emptyList();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This is only used when a LazyReactPackage is a part of {@link CompositeReactPackage} Once we
|
* This is only used when a LazyReactPackage is a part of {@link CompositeReactPackage} Once we
|
||||||
* deprecate {@link CompositeReactPackage}, this can be removed too
|
* deprecate {@link CompositeReactPackage}, this can be removed too
|
||||||
|
@ -32,6 +32,9 @@ public class NativeModuleRegistryBuilder {
|
|||||||
if (reactPackage instanceof LazyReactPackage) {
|
if (reactPackage instanceof LazyReactPackage) {
|
||||||
moduleHolders =
|
moduleHolders =
|
||||||
((LazyReactPackage) reactPackage).getNativeModuleIterator(mReactApplicationContext);
|
((LazyReactPackage) reactPackage).getNativeModuleIterator(mReactApplicationContext);
|
||||||
|
} else if (reactPackage instanceof TurboReactPackage) {
|
||||||
|
moduleHolders =
|
||||||
|
((TurboReactPackage) reactPackage).getNativeModuleIterator(mReactApplicationContext);
|
||||||
} else {
|
} else {
|
||||||
moduleHolders =
|
moduleHolders =
|
||||||
ReactPackageHelper.getNativeModuleIterator(
|
ReactPackageHelper.getNativeModuleIterator(
|
||||||
|
@ -0,0 +1,136 @@
|
|||||||
|
package com.facebook.react;
|
||||||
|
|
||||||
|
import android.support.annotation.NonNull;
|
||||||
|
import com.facebook.react.bridge.ModuleHolder;
|
||||||
|
import com.facebook.react.bridge.ModuleSpec;
|
||||||
|
import com.facebook.react.bridge.NativeModule;
|
||||||
|
import com.facebook.react.bridge.ReactApplicationContext;
|
||||||
|
import com.facebook.react.module.model.ReactModuleInfo;
|
||||||
|
import com.facebook.react.module.model.ReactModuleInfoProvider;
|
||||||
|
import com.facebook.react.uimanager.ViewManager;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.Iterator;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Set;
|
||||||
|
import javax.inject.Provider;
|
||||||
|
|
||||||
|
/** This will eventually replace {@link LazyReactPackage} when TurboModules are finally done. */
|
||||||
|
public abstract class TurboReactPackage implements ReactPackage {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<NativeModule> createNativeModules(ReactApplicationContext reactContext) {
|
||||||
|
throw new UnsupportedOperationException(
|
||||||
|
"In case of TurboModules, createNativeModules is not supported. NativeModuleRegistry should instead use getModuleList or getModule method");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This is only a temporary method to test the impact of initializing some modules eagerly. This
|
||||||
|
* will deleted whenn
|
||||||
|
* qe_react_native_startup_module_optimization.eager_init_current_viewer_native_module is removed
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
protected List<String> getEagerNativeModules() {
|
||||||
|
return Collections.emptyList();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The API needed for TurboModules. Given a module name, it returns an instance of {@link
|
||||||
|
* NativeModule} for the name
|
||||||
|
*
|
||||||
|
* @param name
|
||||||
|
* @param reactContext
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public abstract NativeModule getModule(String name, final ReactApplicationContext reactContext);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This is a temporary method till we implement TurboModules. Once we implement TurboModules, we
|
||||||
|
* will be able to directly call {@link TurboReactPackage#getModule(String,
|
||||||
|
* ReactApplicationContext)} This method will be removed when TurboModule implementation is
|
||||||
|
* complete
|
||||||
|
*
|
||||||
|
* @param reactContext
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Iterable<ModuleHolder> getNativeModuleIterator(
|
||||||
|
final ReactApplicationContext reactContext) {
|
||||||
|
final Set<Map.Entry<String, ReactModuleInfo>> entrySet =
|
||||||
|
getReactModuleInfoProvider().getReactModuleInfos().entrySet();
|
||||||
|
final Iterator<Map.Entry<String, ReactModuleInfo>> entrySetIterator = entrySet.iterator();
|
||||||
|
final List<String> eagerNativeModules = getEagerNativeModules();
|
||||||
|
return new Iterable<ModuleHolder>() {
|
||||||
|
@NonNull
|
||||||
|
@Override
|
||||||
|
// This should ideally be an IteratorConvertor, but we don't have any internal library for it
|
||||||
|
public Iterator<ModuleHolder> iterator() {
|
||||||
|
return new Iterator<ModuleHolder>() {
|
||||||
|
@Override
|
||||||
|
public boolean hasNext() {
|
||||||
|
return entrySetIterator.hasNext();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ModuleHolder next() {
|
||||||
|
Map.Entry<String, ReactModuleInfo> entry = entrySetIterator.next();
|
||||||
|
String name = entry.getKey();
|
||||||
|
ReactModuleInfo reactModuleInfo = entry.getValue();
|
||||||
|
if (eagerNativeModules.contains(name)) {
|
||||||
|
return new ModuleHolder(getModule(name, reactContext));
|
||||||
|
} else {
|
||||||
|
return new ModuleHolder(
|
||||||
|
reactModuleInfo, new ModuleHolderProvider(name, reactContext));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void remove() {
|
||||||
|
throw new UnsupportedOperationException("Cannot remove native modules from the list");
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param reactContext react application context that can be used to create View Managers.
|
||||||
|
* @return list of module specs that can create the View Managers.
|
||||||
|
*/
|
||||||
|
protected List<ModuleSpec> getViewManagers(ReactApplicationContext reactContext) {
|
||||||
|
return Collections.emptyList();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<ViewManager> createViewManagers(ReactApplicationContext reactContext) {
|
||||||
|
List<ModuleSpec> viewManagerModuleSpecs = getViewManagers(reactContext);
|
||||||
|
if (viewManagerModuleSpecs == null || viewManagerModuleSpecs.isEmpty()) {
|
||||||
|
return Collections.emptyList();
|
||||||
|
}
|
||||||
|
|
||||||
|
List<ViewManager> viewManagers = new ArrayList<>();
|
||||||
|
for (ModuleSpec moduleSpec : viewManagerModuleSpecs) {
|
||||||
|
viewManagers.add((ViewManager) moduleSpec.getProvider().get());
|
||||||
|
}
|
||||||
|
return viewManagers;
|
||||||
|
}
|
||||||
|
|
||||||
|
public abstract ReactModuleInfoProvider getReactModuleInfoProvider();
|
||||||
|
|
||||||
|
private class ModuleHolderProvider implements Provider<NativeModule> {
|
||||||
|
|
||||||
|
private final String mName;
|
||||||
|
private final ReactApplicationContext mReactContext;
|
||||||
|
|
||||||
|
public ModuleHolderProvider(String name, ReactApplicationContext reactContext) {
|
||||||
|
mName = name;
|
||||||
|
mReactContext = reactContext;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public NativeModule get() {
|
||||||
|
return getModule(mName, mReactContext);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user