From 4573eca7ad3983676bf0b0fbac071189e5ee5094 Mon Sep 17 00:00:00 2001 From: Szymon Rybczak Date: Sat, 31 Aug 2024 11:22:30 -0400 Subject: [PATCH] perf: skip getting package class name inside expo module (#2487) * perf: skip getting package class name inside expo module * fix: move early return * fix: replace condition validating expo package with `*Package.kt/java` check --- .../src/config/findPackageClassName.ts | 24 ++++++++++++++++--- 1 file changed, 21 insertions(+), 3 deletions(-) diff --git a/packages/cli-platform-android/src/config/findPackageClassName.ts b/packages/cli-platform-android/src/config/findPackageClassName.ts index 39cdd7ff0..5903efa62 100644 --- a/packages/cli-platform-android/src/config/findPackageClassName.ts +++ b/packages/cli-platform-android/src/config/findPackageClassName.ts @@ -32,11 +32,29 @@ export default function getPackageClassName(folder: string) { let files = getMainActivityFiles(folder); let packages = getClassNameMatches(files, folder); - if (!packages.length) { - files = getMainActivityFiles(folder, false); - packages = getClassNameMatches(files, folder); + if (packages && packages.length > 0 && Array.isArray(packages[0])) { + return packages[0][1]; } + /* + When module contains `expo-module.config.json` we return null + because expo modules follow other practices and don't implement + ReactPackage/TurboReactPackage directly, so it doesn't make sense + to scan and read hundreds of files to get package class name. + + Exception is `expo` package itself which contains `expo-module.config.json` + and implements `ReactPackage/TurboReactPackage`. + + Following logic is done due to performance optimization. + */ + + if (fs.existsSync(path.join(folder, '..', 'expo-module.config.json'))) { + return null; + } + + files = getMainActivityFiles(folder, false); + packages = getClassNameMatches(files, folder); + // @ts-ignore return packages.length ? packages[0][1] : null; }