Files
react-native/Libraries/TurboModule/TurboModuleRegistry.js
T
Ramanpreet Nara b5097c8dcd Back out "Back out "[TM][JS] Forward NativeModule schema to __turboModuleProxy""
Summary:
**Note:** This is a carbon copy of D22832730 (https://github.com/facebook/react-native/commit/3df6f5fb2c6176a809cdfef69a91792d3dce7d86). The fixes are stacked on top of this diff, in D22888030.

Changelog: [Internal]

Reviewed By: fkgozali

Differential Revision: D22888032

fbshipit-source-id: 2f1b7ecd39437a3c5ee9c3214419716fde2bbdff
2020-08-04 15:49:52 -07:00

70 lines
2.1 KiB
JavaScript

/**
* Copyright (c) Facebook, Inc. and its affiliates.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*
* @flow strict
* @format
*/
'use strict';
const NativeModules = require('../BatchedBridge/NativeModules');
import type {TurboModule} from './RCTExport';
import invariant from 'invariant';
const turboModuleProxy = global.__turboModuleProxy;
function requireModule<T: TurboModule>(name: string, schema?: ?$FlowFixMe): ?T {
// Bridgeless mode requires TurboModules
if (!global.RN$Bridgeless) {
// Backward compatibility layer during migration.
const legacyModule = NativeModules[name];
if (legacyModule != null) {
return ((legacyModule: $FlowFixMe): T);
}
}
if (turboModuleProxy != null) {
const module: ?T = turboModuleProxy(name, schema);
return module;
}
return null;
}
export function get<T: TurboModule>(name: string): ?T {
/**
* What is Schema?
*
* @react-native/babel-plugin-codegen will parse the NativeModule
* spec, and pass in the generated schema as the second argument
* to this function. The schem will then be used to perform method
* dispatch on, and translate arguments/return to and from the Native
* TurboModule object.
*/
const schema = arguments.length === 2 ? arguments[1] : undefined;
return requireModule<T>(name, schema);
}
export function getEnforcing<T: TurboModule>(name: string): T {
/**
* What is Schema?
*
* @react-native/babel-plugin-codegen will parse the NativeModule
* spec, and pass in the generated schema as the second argument
* to this function. The schem will then be used to perform method
* dispatch on, and translate arguments/return to and from the Native
* TurboModule object.
*/
const schema = arguments.length === 2 ? arguments[1] : undefined;
const module = requireModule<T>(name, schema);
invariant(
module != null,
`TurboModuleRegistry.getEnforcing(...): '${name}' could not be found. ` +
'Verify that a module by this name is registered in the native binary.',
);
return module;
}