UNPKG

create-expo-cljs-app

Version:

Create a react native application with Expo and Shadow-CLJS!

55 lines (48 loc) 1.5 kB
/** * 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. * * @emails oncall+react_native * @flow strict-local * @format */ 'use strict'; const combine = require('./combine-js-to-schema'); const fs = require('fs'); // $FlowFixMe[untyped-import] glob is untyped const glob = require('glob'); const path = require('path'); const [outfile, ...fileList] = process.argv.slice(2); function filterJSFile(file) { return ( /^(Native.+|.+NativeComponent)/.test(path.basename(file)) && // NativeUIManager will be deprecated by Fabric UIManager. // For now, ignore this spec completely because the types are not fully supported. !file.endsWith('NativeUIManager.js') && // NativeSampleTurboModule is for demo purpose. It should be added manually to the // app for now. !file.endsWith('NativeSampleTurboModule.js') && !file.includes('__tests') ); } const allFiles = []; fileList.forEach(file => { if (fs.lstatSync(file).isDirectory()) { const dirFiles = glob .sync(`${file}/**/*.js`, { nodir: true, }) .filter(filterJSFile); allFiles.push(...dirFiles); } else if (filterJSFile(file)) { allFiles.push(file); } }); const formattedSchema = JSON.stringify(combine(allFiles), null, 2); if (outfile != null) { fs.writeFileSync(outfile, formattedSchema); } else { console.log(formattedSchema); }