mirror of
https://github.com/zebrajr/react.git
synced 2025-12-07 00:20:28 +01:00
* Split ReactNativeFiber into separate ReactNativeFiberRenderer module Hopefully this is sufficient to work around Rollup circular dependency problems. (To be seen in subsequent commits...) * Split findNodeHandle into findNodeHandleFiber + findNodeHandleStack This allowed me to remove the ReactNative -> findNodeHandle injections, which should in turn allow me to require a fully-functional findNodeHandle without going through ReactNative. This will hopefully allow ReactNativeBaseomponent to avoid a circular dependency. * Un-forked findNodeHandle in favor of just inlining the findNode function impl * takeSnapshot no longer requires/depends-on ReactNative for findNodeHandle Instead it uses the new, renderer-specific wrappers (eg findNodeHandleFiberWrapper and findNodeHandleStackWrapper) to ensure the returned value is numeric (or null). This avoids a circular dependency that would trip up Rollup. * NativeMethodsMixin requires findNodeHandler wrapper(s) directly rather than ReactNative This works around a potential circular dependency that would break the Rollup build * Add RN_* build targets to hash-finle-name check * Strip @providesModule annotations from headers for RN_* builds * Added process.env.REACT_NATIVE_USE_FIBER to ReactNativeFeatureFlags This is kind of a hacky solution, but it is temporary. It works around the fact that ReactNativeFeatureFlag values need to be set at build time in order to avoid a mismatch between runtime flag values. DOM avoids the need to do this by using injection but Native is not able to use this same approach due to circular dependency issues. * Moved a couple of SECRET exports to dev-only. Removed SyntheticEvent and PooledClass from SECRET exports. Converted Rollup helper function to use named params. * Split NativeMethodsMixins interface and object-type * Add @noflow header to flat-bundle template to avoid triggering Flow problems When Flow tries to infer such a large file, it consumes massive amounts of CPU/RAM and can often lead to programs crashing. It is better for such large files to use .flow.js types instead. * NativeMethodsMixin and ReactNativeFiberHostComponent now share the same Flow type * Collocated (externally exposed) ReactTypes and ReactNativeTypes into single files to be synced to fbsource. ReactNativeFiber and ReactNativeStack use ReactNativeType Flow type * Build script syncs RN types and PooledClass automatically * Added optional sync-RN step to Rollup build script * Added results.json for new RN bundles
38 lines
932 B
JavaScript
38 lines
932 B
JavaScript
'use strict';
|
|
|
|
const asyncCopyTo = require('./utils').asyncCopyTo;
|
|
const chalk = require('chalk');
|
|
const resolvePath = require('./utils').resolvePath;
|
|
|
|
const DEFAULT_FB_SOURCE_PATH = '~/fbsource/';
|
|
const RELATIVE_RN_PATH = 'xplat/js/react-native-github/Libraries/Renderer/';
|
|
|
|
function syncReactNative(buildPath, fbSourcePath) {
|
|
fbSourcePath = typeof fbSourcePath === 'string'
|
|
? fbSourcePath
|
|
: DEFAULT_FB_SOURCE_PATH;
|
|
|
|
if (fbSourcePath.charAt(fbSourcePath.length - 1) !== '/') {
|
|
fbSourcePath += '/';
|
|
}
|
|
|
|
const destPath = resolvePath(fbSourcePath + RELATIVE_RN_PATH);
|
|
|
|
console.log(
|
|
`${chalk.bgYellow.black(' SYNCING ')} ReactNative to ${destPath}`
|
|
);
|
|
|
|
const promise = asyncCopyTo(buildPath, destPath);
|
|
promise.then(() => {
|
|
console.log(
|
|
`${chalk.bgGreen.black(' SYNCED ')} ReactNative to ${destPath}`
|
|
);
|
|
});
|
|
|
|
return promise;
|
|
}
|
|
|
|
module.exports = {
|
|
syncReactNative: syncReactNative,
|
|
};
|