Fabric FB4A integration
Reviewed By: fkgozali Differential Revision: D7953706 fbshipit-source-id: 406f8340eb3706dc07dcd32dcfaa5bdc06981aa1
This commit is contained in:
Родитель
4767f9be45
Коммит
dbc9364b21
|
@ -262,7 +262,7 @@ public class ReactAppTestActivity extends FragmentActivity
|
||||||
@Override
|
@Override
|
||||||
public FabricUIManager getJSIModule() {
|
public FabricUIManager getJSIModule() {
|
||||||
List<ViewManager> viewManagers =
|
List<ViewManager> viewManagers =
|
||||||
getReactInstanceManager().getOrCreateViewManagers(reactApplicationContext);
|
getReactInstanceManager().getOrCreateViewManagers(reactApplicationContext);
|
||||||
FabricUIManager fabricUIManager =
|
FabricUIManager fabricUIManager =
|
||||||
new FabricUIManager(
|
new FabricUIManager(
|
||||||
reactApplicationContext, new ViewManagerRegistry(viewManagers));
|
reactApplicationContext, new ViewManagerRegistry(viewManagers));
|
||||||
|
|
|
@ -85,7 +85,6 @@ import com.facebook.react.views.imagehelper.ResourceDrawableIdHelper;
|
||||||
import com.facebook.soloader.SoLoader;
|
import com.facebook.soloader.SoLoader;
|
||||||
import com.facebook.systrace.Systrace;
|
import com.facebook.systrace.Systrace;
|
||||||
import com.facebook.systrace.SystraceMessage;
|
import com.facebook.systrace.SystraceMessage;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
|
|
|
@ -281,6 +281,6 @@ public class ReactInstanceManagerBuilder {
|
||||||
mDevBundleDownloadListener,
|
mDevBundleDownloadListener,
|
||||||
mMinNumShakes,
|
mMinNumShakes,
|
||||||
mMinTimeLeftInFrameForNonBatchedOperationMs,
|
mMinTimeLeftInFrameForNonBatchedOperationMs,
|
||||||
mJSIModulesProvider);
|
mJSIModulesProvider);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,23 +1,37 @@
|
||||||
package com.facebook.react.bridge;
|
package com.facebook.react.bridge;
|
||||||
|
|
||||||
|
import com.facebook.infer.annotation.Assertions;
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import com.facebook.infer.annotation.Assertions;
|
|
||||||
|
|
||||||
public class JSIModuleRegistry {
|
public class JSIModuleRegistry {
|
||||||
|
|
||||||
|
private final List<JSIModuleHolder> mModuleList = new ArrayList<>();
|
||||||
private final Map<Class, JSIModule> mModules = new HashMap<>();
|
private final Map<Class, JSIModule> mModules = new HashMap<>();
|
||||||
|
private volatile boolean mIsInitialized = false;
|
||||||
|
|
||||||
public JSIModuleRegistry() { }
|
public JSIModuleRegistry() { }
|
||||||
|
|
||||||
public <T extends JSIModule> T getModule(Class<T> moduleClass) {
|
public <T extends JSIModule> T getModule(Class<T> moduleClass) {
|
||||||
|
JSIModule jsiModule = mModules.get(moduleClass);
|
||||||
|
if (jsiModule == null) {
|
||||||
|
initModules();
|
||||||
|
}
|
||||||
return (T) Assertions.assertNotNull(mModules.get(moduleClass));
|
return (T) Assertions.assertNotNull(mModules.get(moduleClass));
|
||||||
}
|
}
|
||||||
|
|
||||||
public void registerModules(List<JSIModuleHolder> jsiModules) {
|
public void registerModules(List<JSIModuleHolder> jsiModules) {
|
||||||
for (JSIModuleHolder holder : jsiModules) {
|
mModuleList.addAll(jsiModules);
|
||||||
mModules.put(holder.getJSIModuleClass(), holder.getJSIModule());
|
}
|
||||||
|
|
||||||
|
public synchronized void initModules() {
|
||||||
|
if (!mIsInitialized) {
|
||||||
|
for (JSIModuleHolder holder : mModuleList) {
|
||||||
|
mModules.put(holder.getJSIModuleClass(), holder.getJSIModule());
|
||||||
|
}
|
||||||
|
mIsInitialized = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Загрузка…
Ссылка в новой задаче