Skip to content

Commit 17f2a56

Browse files
authored
Merge pull request #589 from maiHydrogen/resolve-issue-584
FIX : build failed with an exception due to AGP
2 parents 89f12f8 + 17272dd commit 17f2a56

File tree

1 file changed

+49
-3
lines changed

1 file changed

+49
-3
lines changed

doc/dev_guide/platform_specific_instructions.md

Lines changed: 49 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -25,9 +25,24 @@ You can read more [here](https://docs.flutter.dev/platform-integration/macos/bui
2525

2626
In case you are having a local build failure on macOS due to "audio_session" do check out issue https://github.com/foss42/apidash/issues/510 for solution.
2727

28-
## Android (Work in Progress)
28+
## Android
2929

30-
Add the `multiDexEnabled true` line to the `defaultConfig` section at `android/app/build.gradle file`
30+
In case you are targeting the Android API level <21 or the project and the libraries it references exceed 65,536 methods, you encounter the following build error that indicates your app has reached the limit of the Android build architecture:
31+
32+
```
33+
trouble writing output:
34+
Too many field references: 131000; max is 65536.
35+
You may try using --multi-dex option.
36+
```
37+
38+
OR
39+
40+
```
41+
Conversion to Dalvik format failed:
42+
Unable to execute dex: method ID not in [0, 0xffff]: 65536
43+
```
44+
45+
To solve this problem, add the `multiDexEnabled true` line to the `defaultConfig` section in `android/app/build.gradle file`
3146

3247
```
3348
android {
@@ -39,7 +54,38 @@ android {
3954
}
4055
```
4156

42-
For more information on multidex support, you can refer to the Android developer guide on [Configuring Multidex](https://developer.android.com/studio/build/multidex).
57+
For more information on multidex support, you can refer to the Android developer guide on [Configuring Multidex](https://developer.android.com/studio/build/multidex).
58+
59+
If you are experiencing build failure issues while debugging due to Gradle/JDK/AGP version resolving try upgrading the gradle version by CLI command
60+
61+
```
62+
gradle wrapper --gradle-version <latest compatible version>
63+
```
64+
65+
In case the above command fails, edit the Gradle distribution reference in the `gradle/wrapper/gradle-wrapper.properties` file. The following example sets the Gradle version to 8.8 in the `gradle-wrapper.properties` file.
66+
67+
```
68+
...
69+
distributionUrl = https\://services.gradle.org/distributions/gradle-8.8-bin.zip
70+
...
71+
```
72+
73+
Upgrade AGP by specifying the plugin version in the top-level `build.gradle` file. The following example sets the plugin to version 8.8.0 from the `build.gradle` file:
74+
75+
```
76+
plugins {
77+
...
78+
id 'com.android.application' version '8.8.0' apply false
79+
id 'com.android.library' version '8.8.0' apply false
80+
...
81+
}
82+
```
83+
84+
For more information on:
85+
- Gradle and Java version compatibility, you can refer to [Compatibility Matrix](https://docs.gradle.org/current/userguide/compatibility.html).
86+
- Gradle and Android Gradle Plugin compatibility, you can refer to [Update Gradle](https://developer.android.com/build/releases/gradle-plugin).
87+
88+
Note : It is highly recommended that always ensure gradle and agp versions are compatible with your JDK version not the vice-versa and having atleast JDK 17 is recommmended.
4389

4490
## Web
4591

0 commit comments

Comments
 (0)