-
Notifications
You must be signed in to change notification settings - Fork 24.4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
codegen - javaPackageName is ignored with includesGeneratedCode and react-native codegen #45079
Comments
This is (sadly) a known bug. The issue is happening regardless of you using I have an internal ticket to work on this. |
@cortinico thanks much. Another issue is that
it generates into
"includesGeneratedCode": true,
"outputDir": {
"android": "android/codegen"
} Is this a bug? Shall I open a separate issue for it? |
mmm I'm not sure this follows to your previous statement.
no? |
Sorry if I wasn't clear. I'd expect "includesGeneratedCode": true,
"outputDir": {
"android": "android/codegen"
} to always generate into
it generates into ReproducerApp % ls -la android/codegen/java/com/rtncalculator
total 8
drwxr-xr-x 3 boga staff 96 Jun 20 14:24 .
drwxr-xr-x 4 boga staff 128 Jun 20 14:24 ..
-rw-r--r-- 1 boga staff 1130 Jun 20 14:24 NativeRTNCalculatorSpec.java |
@dmytrorykun can help you more here as he implemented the |
This is definitely a bug. I'll take a look |
@dmytrorykun opened issue #45112 |
We've been hitting this issue in react-native-builder-bob. I've added a script to patch this behavior there. You can find the script here |
## Summary So far with the new architecture-supported templates, we've been generating libraries that didn't ship their codegen-generated specs. This means the library's users had to build the codegen specs on their end (this was done implicitly). With this, the codegen-generated specs are generated at the build time and they are shipped with the library. I've followed [this guide from the React Native new arch working group](https://github.com/reactwg/react-native-new-architecture/blob/main/docs/codegen.md#including-generated-code-into-libraries). ### Making sure example app builds are triggering codegen An important problem to figure out was to make sure the codegen-generated specs were being built with each native build of the example app. To do that,`create-react-native-library` now modifies non-legacy example apps and adds: 1. A new task to `example/android/build.gradle` that's triggered before each native build. 2. A prebuild action to the XCode build schema. 3. A `pre_install` hook to `example/ios/Podfile` that's triggered when user calls `pod install`. These modifications make sure `yarn codegen` is called on the repo root to generate the codegen specs. ### Notes 1. There is an important problem with React Native itself right now. When `react-native codegen` is called, the generated Java code doesn't follow the `codegenConfig.android.javaPackageName` property in the `package.json`. This means the generated Java files are stored in a default location with the wrong package name. To fix it, I've added a script that moves the codegen-generated files into the correct place. You can check facebook/react-native#45079 to see more. ## Test plan ### Test if Android builds trigger codegen 1. Create a non-legacy library using `create-react-native-library` 2. Install the dependencies and build the example app on Android 3. Make sure the build passes, and there are files under `android/generated`. ### Test if installing pods triggers codegen 1. Create a non-legacy library using `create-react-native-library` 2. Install the dependencies and run `pod install` in `example/ios` 3. Make sure the pods are installed and there are files under `ios/generated`. ### Test if iOS builds trigger codegen 1. Create a non-legacy library using `create-react-native-library` 2. Install the dependencies and run `pod install` in `example/ios` 3. Remove the codegen generated code from `ios/generated` since that's generated by the pod install step 4. Build the app for iOS 5. Make sure there are files in `ios/generated`. ### Test if building the library triggers codegen 1. Run `yarn prepare` to emulate the library release process 2. Run `yarn pack` 3. Extract the files from the generated `package.tgz` 4. Make sure there are files under `ios/generated`, and `android/generated` in the generated package.
Thank you man! This script saved my day. For those coming here and wondering how to implement it easily you can: 1. replace the parameter with a constant as follows: - export async function patchCodegen(projectPath: string) {
+ export async function patchCodegen() {
+ const projectPath = process.cwd(); 2. rename the file from .ts to .mjs if you are not using modules 3. add the script call right after calling codegen. (in my case it was for an npm package so it's as below) - "codegen": "npx @react-native-community/cli codegen",
+ "codegen": "npx @react-native-community/cli codegen && node path/patchCodegen.mjs", Working perfectly atm, thank you again @atlj :) |
Description
react-native codegen ignores javaPackageName in package.json/codeGenConfig/andorid/javaPackageName and uses
com.facebook.fbreact.specs
Steps to reproduce
See https://github.com/mfazekas/rn-codegen-javapackagename
See
react-native/packages/react-native/scripts/codegen/generate-artifacts-executor.js
Lines 454 to 462 in 2a6a895
React Native Version
0.74.2
Affected Platforms
Runtime - Android
Areas
Codegen
Output of
npx react-native info
Stacktrace or Logs
Reproducer
https://github.com/mfazekas/rn-codegen-javapackagename/
Screenshots and Videos
No response
The text was updated successfully, but these errors were encountered: